diff --git a/backend-assemblyscript/step-1-template/as-pect.config.js b/backend-assemblyscript/step-1-template/as-pect.config.js deleted file mode 100644 index 30150c7..0000000 --- a/backend-assemblyscript/step-1-template/as-pect.config.js +++ /dev/null @@ -1,69 +0,0 @@ -module.exports = { - /** - * A set of globs passed to the glob package that qualify typescript files for testing. - */ - include: ["assembly/__tests__/**/*.spec.ts"], - /** - * A set of globs passed to the glob package that quality files to be added to each test. - */ - add: ["assembly/__tests__/**/*.include.ts"], - /** - * All the compiler flags needed for this test suite. Make sure that a binary file is output. - */ - flags: { - /** To output a wat file, uncomment the following line. */ - // "--textFile": ["output.wat"], - /** A runtime must be provided here. */ - "--runtime": ["full"] // Acceptable values are: full, half, stub (arena), and none - }, - /** - * A set of regexp that will disclude source files from testing. - */ - disclude: [/node_modules/], - /** - * Add your required AssemblyScript imports here. - */ - imports: {}, - /** - * All performance statistics reporting can be configured here. - */ - performance: { - /** Enable performance statistics gathering for every test. */ - enabled: false, - /** Set the maximum number of samples to run for every test. */ - maxSamples: 10000, - /** Set the maximum test run time in milliseconds for every test. */ - maxTestRunTime: 5000, - /** Report the median time in the default reporter for every test. */ - reportMedian: true, - /** Report the average time in milliseconds for every test. */ - reportAverage: true, - /** Report the standard deviation for every test. */ - reportStandardDeviation: false, - /** Report the maximum run time in milliseconds for every test. */ - reportMax: false, - /** Report the minimum run time in milliseconds for every test. */ - reportMin: false, - }, - /** - * Add a custom reporter here if you want one. The following example is in typescript. - * - * @example - * import { TestReporter, TestGroup, TestResult, TestContext } from "as-pect"; - * - * export class CustomReporter extends TestReporter { - * // implement each abstract method here - * public abstract onStart(suite: TestContext): void; - * public abstract onGroupStart(group: TestGroup): void; - * public abstract onGroupFinish(group: TestGroup): void; - * public abstract onTestStart(group: TestGroup, result: TestResult): void; - * public abstract onTestFinish(group: TestGroup, result: TestResult): void; - * public abstract onFinish(suite: TestContext): void; - * } - */ - // reporter: new CustomReporter(), - /** - * Specify if the binary wasm file should be written to the file system. - */ - outputBinary: false, -}; diff --git a/backend-assemblyscript/step-1-template/assembly/__tests__/as-pect.d.ts b/backend-assemblyscript/step-1-template/assembly/__tests__/as-pect.d.ts deleted file mode 100644 index 0a5912a..0000000 --- a/backend-assemblyscript/step-1-template/assembly/__tests__/as-pect.d.ts +++ /dev/null @@ -1,865 +0,0 @@ -/** - * This function creates a test group in the test loader. - * - * @param {string} description - This is the name of the test group. - * @param {() => void} callback - A function that contains all of the closures for this test group. - * - * @example - * - * ```ts - * describe("my test suite", (): void => { - * // put your tests here - * }); - * ``` - */ -declare function describe(description: string, callback: () => void): void; - -/** - * This function creates a test inside the given test group. It must be placed inside a describe - * block. - * - * @param {string} description - This is the name of the test, and should describe a behavior. - * @param {() => void} callback - A function that contains a set of expectations for this test. - * - * @example - * - * ```ts - * describe("the meaning of life", (): void => { - * it("should be 42", (): void => { - * // put your expectations here - * expect(29 + 13).toBe(42); - * }); - * }); - * ``` - */ -declare function it(description: string, callback: () => void): void; - -/** - * A test that does not run, and is longhand equivalent to using todo function without a - * callback. This test does not get run and is reported like a todo. - * - * @param {string} description - This is the name of the test, and should describe a behavior. - * @param {() => void} callback - A function that contains a set of expectations for this test. - */ -declare function xit(description: string, callback: () => void): void; - -/** - * A test that does not run, and is longhand equivalent to using todo function without a - * callback. This test does not get run and is reported like a todo. - * - * @param {string} description - This is the name of the test, and should describe a behavior. - * @param {() => void} callback - A function that contains a set of expectations for this test. - */ -declare function xtest(description: string, callback: () => void): void; - -/** - * This function creates a test inside the given test group. It must be placed inside a describe - * block. - * - * @param {string} description - This is the name of the test, and should describe a behavior. - * @param {() => void} callback - A function that contains a set of expectations for this test. - * - * @example - * ```ts - * describe("the meaning of life", (): void => { - * test("the value should be 42", (): void => { - * // put your expectations here - * expect(29 + 13).toBe(42); - * }); - * }); - * ``` - */ -declare function test(description: string, callback: () => void): void; - -/** - * This function creates a test that is expected to fail. This is useful to verify if a given - * behavior is expected to throw. - * - * @param {string} description - This is the name of the test, and should describe a behavior. - * @param {() => void} callback - A function that contains a set of expectations for this test. - * @param {string?} message - A message that describes why the test should fail. - * - * @example - * - * ```ts - * describe("the meaning of life", (): void => { - * throws("the value should be 42", (): void => { - * // put your expectations here - * expect(29 + 13).not.toBe(42); - * }); - * }); - * ``` - */ -declare function throws(description: string, callback: () => void, message?: string): void; - - -/** - * This function creates a test that is expected to fail. This is useful to verify if a given - * behavior is expected to throw. - * - * @param {string} description - This is the name of the test, and should describe a behavior. - * @param {() => void} callback - A function that contains a set of expectations for this test. - * @param {string?} message - A message that describes why the test should fail. - * - * @example - * - * ```ts - * describe("the meaning of life", (): void => { - * itThrows("when the value should be 42", (): void => { - * // put your expectations here - * expect(29 + 13).not.toBe(42); - * }, "The value is actually 42."); - * }); - * ``` - */ -declare function itThrows(description: string, callback: () => void, message?: string): void; - -/** - * This function creates a callback that is called before each individual test is run in this test - * group. - * - * @param {function} callback - The function to be run before each test in the current test group. - * - * @example - * - * ```ts - * // create a global - * var cat: Cat = new Cat(); - * - * describe("cats", (): void => { - * beforeEach((): void => { - * cat.meow(1); // meow once per test - * }); - * }); - * ``` - */ -declare function beforeEach(callback: () => void): void; - -/** - * This function creates a callback that is called before the whole test group is run, and only - * once. - * - * @param {function} callback - The function to be run before each test in the current test group. - * - * @example - * - * ```ts - * // create a global - * var dog: Dog = null; - * describe("dogs", (): void => { - * beforeAll((): void => { - * dog = new Dog(); // create a single dog once before the tests start - * }); - * }); - * ``` - */ -declare function beforeAll(callback: () => void): void; - -/** - * This function creates a callback that is called after each individual test is run in this test - * group. - * - * @param {function} callback - The function to be run after each test in the current test group. - * - * @example - * - * ```ts - * // create a global - * var cat: Cat = new Cat(); - * - * describe("cats", (): void => { - * afterEach((): void => { - * cat.sleep(12); // cats sleep a lot - * }); - * }); - * ``` - */ -declare function afterEach(callback: () => void): void; - -/** - * This function creates a callback that is called after the whole test group is run, and only - * once. - * - * @param {function} callback - The function to be run after each test in the current test group. - * - * @example - * - * ```ts - * // create a global - * var dog: Dog = null; - * describe("dogs", (): void => { - * afterAll((): void => { - * memory.free(changetype(dog)); // free some memory - * }); - * }); - * ``` - */ -declare function afterAll(callback: () => void): void; - -/** - * Describes a value and returns an expectation to test the value. - * - * @type {T} - The expectation's type. - * @param {T} actual - The value being tested. - * - * @example - * - * ```ts - * expect(42).not.toBe(-1, "42 should not be -1"); - * expect(19 + 23).toBe(42, "19 + 23 should equal 42"); - * ``` - */ -declare function expect(actual: T | null): Expectation; - -/** - * Describes a void function and returns an expectation to test the function. - * - * @param {() => void} callback - The callback being tested. - * - * @example - * - * ```ts - * expectFn((): void => unreachable()).toThrow("unreachables do not throw"); - * expectFn((): void => { - * cat.meow(); - * }).not.toThrow("Uhoh, cats can't meow!");; - * ``` - */ -declare function expectFn(cb: () => void): Expectation<() => void>; - -/** - * Describes a test that needs to be written. - * - * @param {string} description - The description of the test that needs to be written. - */ -declare function todo(description: string): void; - -/** - * Logs a single value to the logger, and is stringified. It works for references, values, and - * strings. - * - * @type {T} - The type to be logged. - * @param {T | null} value - The value to be logged. - * - * @example - * - * ```ts - * log("This is a logged value."); - * log(42); - * log(new Vec(1, 2, 3)); - * log(null); - * ``` - */ -declare function log(value: T | null): void; - -/** - * An expectation for a value. - */ -// @ts-ignore -declare class Expectation { - - /** - * Create a new expectation. - * - * @param {T | null} actual - The actual value of the expectation. - */ - constructor(actual: T | null); - - /** - * This expectation performs a strict equality on value types and reference types. - * - * @param {T | null} expected - The value to be compared. - * @param {string} message - The optional message that describes the expectation. - * - * @example - * - * ```ts - * expect(42).not.toBe(-1, "42 should not be -1"); - * expect(19 + 23).toBe(42, "19 + 23 should equal 42"); - * ``` - */ - toBe(expected: T | null, message?: string): void; - - /** - * This expectation performs a strict equality on value types and performs a memcompare on - * reference types. If the reference type `T` has reference types as properties, the comparison does - * not perform property traversal. It will only compare the pointer values in the memory block, and - * only compare `offsetof()` bytes, regardless of the allocated block size. - * - * @param {T | null} expected - The value to be compared. - * @param {string} message - The optional message that describes the expectation. - * - * @example - * - * ```ts - * expect(new Vec3(1, 2, 3)).toStrictEqual(new Vec(1, 2, 3), "Vectors of the same shape should be equal"); - * ``` - */ - toStrictEqual(expected: T | null, message?: string): void; - - /** - * This expectation performs a strict memory block equality based on the allocated block sizes. - * - * @param {T | null} expected - The value to be compared. - * @param {string} message - The optional message that describes the expectation. - * - * @example - * - * ```ts - * expect(new Vec3(1, 2, 3)).toBlockEqual(new Vec(1, 2, 3), "Vectors of the same shape should be equal"); - * ``` - */ - toBlockEqual(expected: T | null, message?: string): void; - - /** - * If the value is callable, it calls the function, and fails the expectation if it throws, or hits - * an unreachable(). - * - * @param {string} message - The optional message that describes the expectation. - * - * @example - * - * ```ts - * expectFn((): void => unreachable()).toThrow("unreachable() should throw."); - * expectFn((): void => { - * cat.sleep(100); // cats can sleep quite a lot - * }).not.toThrow("cats should sleep, not throw"); - * ``` - */ - toThrow(message?: string): void; - - /** - * This expecation asserts that the value is truthy, like in javascript. If the value is a string, - * then strings of length 0 are not truthy. - * - * @param {string} message - The optional message that describes the expectation. - * - * @example - * - * ```ts - * expect(true).toBeTruthy("true is truthy."); - * expect(1).toBeTruthy("numeric values that are not 0 are truthy."); - * expect(new Vec3(1, 2, 3)).toBeTruthy("reference types that aren't null are truthy."); - * expect(false).not.toBeTruthy("false is not truthy."); - * expect(0).not.toBeTruthy("0 is not truthy."); - * expect(null).not.toBeTruthy("null is not truthy."); - * ``` - */ - toBeTruthy(message?: string): void; - - /** - * This expectation tests the value to see if it is null. If the value is a value type, it is - * never null. If the value is a reference type, it performs a strict null comparison. - * - * @param {string} message - The optional message that describes the expectation. - * - * @example - * - * ```ts - * expect(0).not.toBeNull("numbers are never null"); - * expect(null).toBeNull("null reference types are null."); - * ``` - */ - toBeNull(message?: string): void; - - /** - * This expecation assert that the value is falsy, like in javascript. If the value is a string, - * then strings of length 0 are falsy. - * - * @param {string} message - The optional message that describes the expectation. - * - * @example - * - * ```ts - * expect(false).toBeFalsy("false is falsy."); - * expect(0).toBeFalsy("0 is falsy."); - * expect(null).toBeFalsy("null is falsy."); - * expect(true).not.toBeFalsy("true is not falsy."); - * expect(1).not.toBeFalsy("numeric values that are not 0 are not falsy."); - * expect(new Vec3(1, 2, 3)).not.toBeFalsy("reference types that aren't null are not falsy."); - * ``` - */ - toBeFalsy(message?: string): void; - - /** - * This expectation asserts that the value is greater than the expected value. Since operators can - * be overloaded in assemblyscript, it's possible for this to work on reference types. - * - * @param {T | null} expected - The expected value that the actual value should be greater than. - * @param {string} message - The optional message that describes this expectation. - * - * @example - * - * ```ts - * expect(10).toBeGreaterThan(4); - * expect(12).not.toBeGreaterThan(42); - * ``` - */ - toBeGreaterThan(expected: T | null, message?: string): void; - - /** - * This expectation asserts that the value is less than the expected value. Since operators can - * be overloaded in assemblyscript, it's possible for this to work on reference types. - * - * @param {T | null} value - The expected value that the actual value should be less than. - * @param {string} message - The optional message that describes this expectation. - * - * @example - * - * ```ts - * expect(10).not.toBeLessThan(4); - * expect(12).toBeLessThan(42); - * ``` - */ - toBeLessThan(expected: T | null, message?: string): void; - - /** - * This expectation asserts that the value is greater than or equal to the expected value. Since - * operators can be overloaded in assemblyscript, it's possible for this to work on reference - * types. - * - * @param {T | null} value - The expected value that the actual value should be greater than or - * equal to. - * @param {string} message - The optional message that describes this expectation. - * - * @example - * - * ```ts - * expect(42).toBeGreaterThanOrEqual(42); - * expect(10).toBeGreaterThanOrEqual(4); - * expect(12).not.toBeGreaterThanOrEqual(42); - * ``` - */ - toBeGreaterThanOrEqual(expected: T | null, message?: string): void; - - /** - * This expectation asserts that the value is less than or equal to the expected value. Since - * operators can be overloaded in assemblyscript, it's possible for this to work on reference - * types. - * - * @param {T | null} value - The expected value that the actual value should be less than or equal - * to. - * @param {string} message - The optional message that describes this expectation. - * - * @example - * - * ```ts - * expect(42).toBeLessThanOrEqual(42); - * expect(10).not.toBeLessThanOrEqual(4); - * expect(12).toBeLessThanOrEqual(42); - * ``` - */ - toBeLessThanOrEqual(expected: T | null, message?: string): void; - - /** - * This expectation asserts that the value is close to another value. Both numbers must be finite, - * and T must extend f64 or f32. - * - * @param {T extends f64 | f32} value - The expected value to be close to. - * @param {i32} decimalPlaces - The number of decimal places used to calculate epsilon. Default is - * 2. - * @param {string} message - The optional message that describes this expectation. - * - * @example - * - * ```ts - * expect(0.1 + 0.2).toBeCloseTo(0.3); - * ``` - */ - toBeCloseTo(expected: T, decimalPlaces?: number, message?: string): void; - - /** - * This function asserts the float type value is NaN. - * - * @param {string} message - The optional message the describes this expectation. - * - * @example - * - * ```ts - * expect(NaN).toBeNaN(); - * expect(42).not.toBeNaN(); - * ``` - */ - toBeNaN(message?: string): void; - - /** - * This function asserts a float is finite. - * - * @param {string} message - The optional message the describes this expectation. - * @example - * - * ```ts - * expect(42).toBeFinite(); - * expect(Infinity).not.toBeFinite(); - * ``` - */ - toBeFinite(message?: string): void; - - /** - * This method asserts the item has the expected length. - * - * @param {i32} expected - The expected length. - * @param {string} message - The optional message the describes this expectation. - * - * ```ts - * expect([1, 2, 3]).toHaveLength(3); - * ``` - */ - toHaveLength(expected: i32, message?: string): void; - - /** - * This method asserts that a given T that extends `Array` has a value/reference included. - * - * @param {valueof} expected - The expected item to be included in the Array. - * @param {string} message - The optional message the describes this expectation. - * - * @example - * - * ```ts - * expect([1, 2, 3]).toInclude(3); - * ``` - */ - // @ts-ignore: expected value should be known at compile time - toInclude(expected: valueof, message?: string): void; - - /** - * This method asserts that a given T that extends `Array` has a value/reference included. - * - * @param {valueof} expected - The expected item to be included in the Array. - * @param {string} message - The optional message the describes this expectation. - * - * @example - * - * ```ts - * expect([1, 2, 3]).toContain(3); - * ``` - */ - // @ts-ignore: expected value should be known at compile time - toContain(expected: valueof, message?: string): void; - - /** - * This method asserts that a given T that extends `Array` has a value/reference included and - * compared via memory.compare(). - * - * @param {i32} expected - The expected item to be included in the Array. - * @param {string} message - The optional message the describes this expectation. - * - * @example - * ```ts - * expect([new Vec3(1, 2, 3)]).toInclude(new Vec3(1, 2, 3)); - * ``` - */ - // @ts-ignore: expected value should be known at compile time - toIncludeEqual(expected: valueof, message?: string): void; - - /** - * This method asserts that a given T that extends `Array` has a value/reference included and - * compared via memory.compare(). - * - * @param {i32} expected - The expected item to be included in the Array. - * @param {string} message - The optional message the describes this expectation. - * - * @example - * ```ts - * expect([new Vec3(1, 2, 3)]).toInclude(new Vec3(1, 2, 3)); - * ``` - */ - // @ts-ignore: expected value should be known at compile time - toContainEqual(expected: valueof, message?: string): void; - - /** - * This computed property is chainable, and negates the existing expectation. It returns itself. - * - * @example - * ```ts - * expect(42).not.toBe(0, "42 is not 0"); - */ - not: Expectation; - - /** - * The actual value of the expectation. - */ - actual: T | null; -} - -/** - * This is called to stop the debugger. e.g. `node --inspect-brk asp`. - */ -declare function debug(): void; - -/** - * This class contains a set of methods related to performance configuration. - */ -// @ts-ignore -declare class Performance { - /** - * This function call enables performance statistics gathering for the following test. - * - * @param {bool} enabled - The bool to indicate if performance statistics should be gathered. - */ - public static enabled(enabled: bool): void; - - /** - * This function call sets the maximum number of samples to complete the following test. - * - * @param {f64} count - The maximum number of samples required. - */ - public static maxSamples(count: f64): void; - - /** - * This function call sets the number of decimal places to round to for the following test. - * - * @param {i32} deicmalPlaces - The number of decimal places to round to - */ - public static roundDecimalPlaces(count: i32): void; - - /** - * This function call will set the maximum amount of time that should pass before it can stop - * gathering samples for the following test. - * - * @param {f64} time - The ammount of time in milliseconds. - */ - public static maxTestRunTime(time: f64): void; - - /** - * This function call enables gathering the average/mean run time of each sample for the following - * test. - * - * @param {bool} enabled - The bool to indicate if the average/mean should be gathered. - */ - public static reportAverage(enabled: bool): void; - - /** - * This function call enables gathering the median run time of each sample for the following test. - * - * @param {bool} enabled - The bool to indicate if the median should be gathered. - */ - public static reportMedian(value: bool): void; - - /** - * This function call enables gathering the standard deviation of the run times of the samples - * collected for the following test. - * - * @param {bool} enabled - The bool to indicate if the standard deviation should be gathered. - */ - public static reportStdDev(value: bool): void; - - /** - * This function call enables gathering the largest run time of the samples collected for the - * following test. - * - * @param {bool} enabled - The bool to indicate if the max should be gathered. - */ - public static reportMax(value: bool): void; - - /** - * This function call enables gathering the smallest run time of the samples collected for the - * following test. - * - * @param {bool} enabled - The bool to indicate if the min should be gathered. - */ - public static reportMin(value: bool): void; - - /** - * This function call enables gathering the varaince of the samples collected for the following test. - * - * @param {bool} enabled - The bool to indicate if the variance should be calculated. - */ - public static reportVariance(value: bool): void; -} -/** - * Assemblyscript uses reference counting to perform garbage collection. This means when you - * allocate a managed object and return it, it's reference count is one. If another variable aliases - * it then the reference count goes up. This static class contains a few convenience methods for - * developers to test the current number of blocks allocated on the heap to make sure you aren't leaking - * references, e.i. keeping references to objects you expect to be collected. - */ -declare class RTrace { - /** - * This bool indicates if `RTrace` should call into JavaScript to obtain reference counts. - */ - public static enabled: bool; - - /** - * This method returns the current number of active references on the heap. - */ - public static count(): i32; - - /** - * This method starts a new refcounting group, and causes the next call to `RTrace.end(label)` to - * return a delta in reference counts on the heap. - * - * @param {i32} label - The numeric label for this refcounting group. - */ - public static start(label: i32): void; - - /** - * This method returns a delta of how many new (positive) or collected (negative) are on the heap. - * - * @param {i32} label - The numeric label for this refcounting group. - */ - public static end(label: i32): i32; - - /** - * This method returns the number of increments that have occurred over the course of a test - * file. - */ - public static increments(): i32; - - /** - * This method returns the number of decrements that have occurred over the course of a test - * file. - */ - public static decrements(): i32; - - /** - * This method returns the number of increments that have occurred over the course of a test - * group. - */ - public static groupIncrements(): i32; - - /** - * This method returns the number of decrements that have occurred over the course of a test - * group. - */ - public static groupDecrements(): i32; - - /** - * This method returns the number of increments that have occurred over the course of a test - * group. - */ - public static testIncrements(): i32; - - /** - * This method returns the number of decrements that have occurred over the course of a test - * group. - */ - public static testDecrements(): i32; - - /** - * This method returns the number of allocations that have occurred over the course of a test - * file. - */ - public static allocations(): i32; - - /** - * This method returns the number of frees that have occurred over the course of a test - * file. - */ - public static frees(): i32; - - /** - * This method returns the number of allocations that have occurred over the course of a test - * group. - */ - public static groupAllocations(): i32; - - /** - * This method returns the number of frees that have occurred over the course of a test - * group. - */ - public static groupFrees(): i32; - - /** - * This method returns the number of allocations that have occurred over the course of a test - * group. - */ - public static testAllocations(): i32; - - /** - * This method returns the number of frees that have occurred over the course of a test - * group. - */ - public static testFrees(): i32; - - /** - * This method triggers a garbage collection. - */ - public static collect(): void; - - /** - * Get the class id of the pointer. - * - * @param {usize} pointer - The pointer. - * @returns {u32} - The class id of the allocated block. - */ - public static classIdOf(pointer: usize): u32; - - /** - * Get the size of a block or buffer. - * - * @param {T} reference - The reference. - * @returns {u32} - The size of the allocated block. - */ - public static sizeOf(reference: T): u32; - - /** - * Get the currently allocated blocks. - */ - public static activeBlocks(): usize[]; - - /** - * Get the current groups allocated blocks. - */ - public static activeGroupBlocks(): usize[]; - - /** - * Get the current tests allocated blocks. - */ - public static activeTestBlocks(): usize[]; -} - - -/** - * This class is static and contains private global values that contain metadata about the Actual - * value. - * - * @example - * ```ts - * Actual.report("This is an expected string."); - * Actual.report([1, 2, 3]); - * Actual.report(42); - * ``` - */ -declare class Actual { - /** - * This function performs reporting to javascript what the actual value of this expectation is. - * - * @param {T} actual - The actual value to be reported. - */ - public static report(value: T): void; - - /** - * Clear the actual value and release any private memory stored as a global. - */ - public static clear(): void; -} - - -/** - * This class is static and contains private global values that contain metadata about the Expected - * value. - * - * @example - * ```ts - * Expected.report("This is an expected string."); - * Expected.report([1, 2, 3]); - * Expected.report(42, i32(true)); // not 42 - * ``` - */ -declare class Expected { - /** - * This function performs reporting to javascript what the expected value of this expectation is. - * It notifies javascript if the expectation is negated. - * - * @param {T} value - The actual value to be reported. - * @param {i32} negated - An indicator if the expectation is negated. Pass `1` to negate the - * expectation. (default: 0) - */ - public static report(value: T, negated?: i32): void; - - /** - * Clear the expected value and release any private memory stored as a global. - */ - public static clear(): void; -} diff --git a/backend-assemblyscript/step-1-template/assembly/__tests__/twit.spec.ts b/backend-assemblyscript/step-1-template/assembly/__tests__/twit.spec.ts deleted file mode 100644 index c16949e..0000000 --- a/backend-assemblyscript/step-1-template/assembly/__tests__/twit.spec.ts +++ /dev/null @@ -1,15 +0,0 @@ -import {handler} from "../main"; - -describe("example", () => { - - it("can log some values to the console", () => { - log("Hello world!"); // strings! - log(3.1415); // floats! - log(244); // integers! - log(0xFFFFFFFF); // long values! - log(handler('{"hi": "hi"}')); - log(handler('{"action": "Post", "msg": "Hello, Fluence!", "handle": "fluencer"}')); - log(handler('{"action": "Post", "msg": "Hello, fluencer!", "handle": "John Doe"}')); - log(handler('{"action": "Fetch"}')); - }); -}); diff --git a/backend-assemblyscript/step-1-template/assembly/index.ts b/backend-assemblyscript/step-1-template/assembly/index.ts index 9c857e6..705b411 100644 --- a/backend-assemblyscript/step-1-template/assembly/index.ts +++ b/backend-assemblyscript/step-1-template/assembly/index.ts @@ -1,4 +1,3 @@ - import {handler} from "./main"; import {loggedStringHandler} from "../node_modules/assemblyscript-sdk/assembly/index"; import {log} from "../node_modules/assemblyscript-sdk/assembly/logger"; diff --git a/backend-assemblyscript/step-1-template/assembly/main.ts b/backend-assemblyscript/step-1-template/assembly/main.ts index 8050bbb..d3ff54c 100644 --- a/backend-assemblyscript/step-1-template/assembly/main.ts +++ b/backend-assemblyscript/step-1-template/assembly/main.ts @@ -1,23 +1,4 @@ -import {Action, decode, PostRequest} from "./request"; -import {SuccessPostResponse, Twit, TwitsResponse, UnknownResponse} from "./response"; - -let twitList: Array = new Array(); - // main handler for an application export function handler(input: string): string { - - let request = decode(input); - - if (request.action == Action.Post) { - let post = request as PostRequest; - twitList.push(new Twit(post.msg, post.handle)); - let response = new SuccessPostResponse(twitList.length); - return response.serialize() - } else if (request.action == Action.Fetch) { - let response = new TwitsResponse(twitList); - return response.serialize() - } - - let response = new UnknownResponse(); - return response.serialize(); + return "Hello, " + input + "!"; } diff --git a/backend-assemblyscript/step-1-template/assembly/request.ts b/backend-assemblyscript/step-1-template/assembly/request.ts deleted file mode 100644 index be585cc..0000000 --- a/backend-assemblyscript/step-1-template/assembly/request.ts +++ /dev/null @@ -1,85 +0,0 @@ -import {JSONDecoder, JSONHandler} from "../node_modules/assemblyscript-json/assembly/decoder"; - -export enum Action { - Post, - Fetch, - Unknown - // Error -} - -export abstract class Request { - public action: Action = Action.Unknown; -} - -export class PostRequest extends Request { - - public readonly msg: string; - public readonly handle: string; - - constructor(msg: string, handle: string) { - super(); - this.msg = msg; - this.handle = handle; - this.action = Action.Post; - } -} - -export class FetchRequest extends Request { - constructor() { - super(); - this.action = Action.Fetch; - } -} - -export class UnknownRequest extends Request { - constructor() { - super(); - this.action = Action.Unknown; - } -} - -export function string2Bytes(str: string): Uint8Array { - return Uint8Array.wrap(String.UTF8.encode(str)); -} - -export function decode(input: string): Request { - let jsonHandler = new RequestJSONEventsHandler(); - let decoder = new JSONDecoder(jsonHandler); - - let bytes = string2Bytes(input); - - decoder.deserialize(bytes); - - let action = jsonHandler.action; - - let request: Request; - - if (action == "Fetch") { - request = new FetchRequest(); - } else if (action == "Post") { - request = new PostRequest(jsonHandler.msg, jsonHandler.handle) - } else { - request = new UnknownRequest() - } - - return request; -} - -class RequestJSONEventsHandler extends JSONHandler { - - public action: string; - public msg: string; - public handle: string; - - setString(name: string, value: string): void { - - if (name == "action") { - this.action = value; - } else if (name == "msg") { - this.msg = value; - } else if (name == "handle") { - this.handle = value; - } - // json scheme is not strict, so we won't throw an error on excess fields - } -} diff --git a/backend-assemblyscript/step-1-template/assembly/response.ts b/backend-assemblyscript/step-1-template/assembly/response.ts deleted file mode 100644 index 63b0592..0000000 --- a/backend-assemblyscript/step-1-template/assembly/response.ts +++ /dev/null @@ -1,79 +0,0 @@ -import {JSONEncoder} from "../node_modules/assemblyscript-json/assembly/encoder"; - -export abstract class Response { - serialize(): string { - unreachable(); - return ""; - }; -} - -export class Twit { - msg: string; - handle: string; - - constructor(msg: string, handle: string) { - this.msg = msg; - this.handle = handle; - } -} - -export class UnknownResponse extends Response { - constructor() { - super(); - } - - serialize(): string { - let encoder = new JSONEncoder(); - encoder.pushObject(null); - encoder.setString("action", "Unknown"); - encoder.setString("msg", "cannot handle request"); - encoder.popObject(); - - return encoder.toString(); - } -} - -export class SuccessPostResponse extends Response { - numberOfTwits: i32; - constructor(numberOfTwits: i32) { - super(); - this.numberOfTwits = numberOfTwits; - } - - serialize(): string { - let encoder = new JSONEncoder(); - encoder.pushObject(null); - encoder.setString("action", "Post"); - encoder.setInteger("number_of_twits", this.numberOfTwits); - encoder.popObject(); - - return encoder.toString(); - } -} - -export class TwitsResponse extends Response { - twitList: Array; - - constructor(twitList: Array) { - super(); - this.twitList = twitList; - } - - serialize(): string { - let encoder = new JSONEncoder(); - encoder.pushObject(null); - encoder.setString("action", "Fetch"); - encoder.pushArray("twit_list"); - for (let i = 0; i < this.twitList.length; i++) { - let twit = this.twitList[i]; - encoder.pushObject(null); - encoder.setString("msg", twit.msg); - encoder.setString("handle", twit.handle); - encoder.popObject(); - } - encoder.popArray(); - encoder.popObject(); - - return encoder.toString(); - } -}