diff --git "a/.\\.cache/deps/https/deno.land/688e058fb547030f059b02f08b6bc2f36f15d56e6edb3bce6b48fdf563fb7ae9" "b/.\\.cache/deps/https/deno.land/688e058fb547030f059b02f08b6bc2f36f15d56e6edb3bce6b48fdf563fb7ae9" deleted file mode 100644 index 7657d42..0000000 --- "a/.\\.cache/deps/https/deno.land/688e058fb547030f059b02f08b6bc2f36f15d56e6edb3bce6b48fdf563fb7ae9" +++ /dev/null @@ -1,622 +0,0 @@ -// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. -// This module is browser compatible. Do not rely on good formatting of values -// for AssertionError messages in browsers. - -import { bold, gray, green, red, stripColor, white } from "../fmt/colors.ts"; -import { diff, DiffResult, DiffType } from "./_diff.ts"; - -const CAN_NOT_DISPLAY = "[Cannot display]"; - -interface Constructor { - // deno-lint-ignore no-explicit-any - new (...args: any[]): any; -} - -export class AssertionError extends Error { - constructor(message: string) { - super(message); - this.name = "AssertionError"; - } -} - -/** - * Converts the input into a string. Objects, Sets and Maps are sorted so as to - * make tests less flaky - * @param v Value to be formatted - */ -export function _format(v: unknown): string { - return globalThis.Deno - ? Deno.inspect(v, { - depth: Infinity, - sorted: true, - trailingComma: true, - compact: false, - iterableLimit: Infinity, - }) - : `"${String(v).replace(/(?=["\\])/g, "\\")}"`; -} - -/** - * Colors the output of assertion diffs - * @param diffType Difference type, either added or removed - */ -function createColor(diffType: DiffType): (s: string) => string { - switch (diffType) { - case DiffType.added: - return (s: string): string => green(bold(s)); - case DiffType.removed: - return (s: string): string => red(bold(s)); - default: - return white; - } -} - -/** - * Prefixes `+` or `-` in diff output - * @param diffType Difference type, either added or removed - */ -function createSign(diffType: DiffType): string { - switch (diffType) { - case DiffType.added: - return "+ "; - case DiffType.removed: - return "- "; - default: - return " "; - } -} - -function buildMessage(diffResult: ReadonlyArray>): string[] { - const messages: string[] = []; - messages.push(""); - messages.push(""); - messages.push( - ` ${gray(bold("[Diff]"))} ${red(bold("Actual"))} / ${ - green(bold("Expected")) - }`, - ); - messages.push(""); - messages.push(""); - diffResult.forEach((result: DiffResult): void => { - const c = createColor(result.type); - messages.push(c(`${createSign(result.type)}${result.value}`)); - }); - messages.push(""); - - return messages; -} - -function isKeyedCollection(x: unknown): x is Set { - return [Symbol.iterator, "size"].every((k) => k in (x as Set)); -} - -/** - * Deep equality comparison used in assertions - * @param c actual value - * @param d expected value - */ -export function equal(c: unknown, d: unknown): boolean { - const seen = new Map(); - return (function compare(a: unknown, b: unknown): boolean { - // Have to render RegExp & Date for string comparison - // unless it's mistreated as object - if ( - a && - b && - ((a instanceof RegExp && b instanceof RegExp) || - (a instanceof URL && b instanceof URL)) - ) { - return String(a) === String(b); - } - if (a instanceof Date && b instanceof Date) { - const aTime = a.getTime(); - const bTime = b.getTime(); - // Check for NaN equality manually since NaN is not - // equal to itself. - if (Number.isNaN(aTime) && Number.isNaN(bTime)) { - return true; - } - return a.getTime() === b.getTime(); - } - if (Object.is(a, b)) { - return true; - } - if (a && typeof a === "object" && b && typeof b === "object") { - if (seen.get(a) === b) { - return true; - } - if (Object.keys(a || {}).length !== Object.keys(b || {}).length) { - return false; - } - if (isKeyedCollection(a) && isKeyedCollection(b)) { - if (a.size !== b.size) { - return false; - } - - let unmatchedEntries = a.size; - - for (const [aKey, aValue] of a.entries()) { - for (const [bKey, bValue] of b.entries()) { - /* Given that Map keys can be references, we need - * to ensure that they are also deeply equal */ - if ( - (aKey === aValue && bKey === bValue && compare(aKey, bKey)) || - (compare(aKey, bKey) && compare(aValue, bValue)) - ) { - unmatchedEntries--; - } - } - } - - return unmatchedEntries === 0; - } - const merged = { ...a, ...b }; - for ( - const key of [ - ...Object.getOwnPropertyNames(merged), - ...Object.getOwnPropertySymbols(merged), - ] - ) { - type Key = keyof typeof merged; - if (!compare(a && a[key as Key], b && b[key as Key])) { - return false; - } - } - seen.set(a, b); - return true; - } - return false; - })(c, d); -} - -/** Make an assertion, error will be thrown if `expr` does not have truthy value. */ -export function assert(expr: unknown, msg = ""): asserts expr { - if (!expr) { - throw new AssertionError(msg); - } -} - -/** - * Make an assertion that `actual` and `expected` are equal, deeply. If not - * deeply equal, then throw. - * - * Type parameter can be specified to ensure values under comparison have the same type. - * For example: - *```ts - *assertEquals(1, 2) - *``` - */ -export function assertEquals( - actual: unknown, - expected: unknown, - msg?: string, -): void; -export function assertEquals(actual: T, expected: T, msg?: string): void; -export function assertEquals( - actual: unknown, - expected: unknown, - msg?: string, -): void { - if (equal(actual, expected)) { - return; - } - let message = ""; - const actualString = _format(actual); - const expectedString = _format(expected); - try { - const diffResult = diff( - actualString.split("\n"), - expectedString.split("\n"), - ); - const diffMsg = buildMessage(diffResult).join("\n"); - message = `Values are not equal:\n${diffMsg}`; - } catch { - message = `\n${red(CAN_NOT_DISPLAY)} + \n\n`; - } - if (msg) { - message = msg; - } - throw new AssertionError(message); -} - -/** - * Make an assertion that `actual` and `expected` are not equal, deeply. - * If not then throw. - * - * Type parameter can be specified to ensure values under comparison have the same type. - * For example: - *```ts - *assertNotEquals(1, 2) - *``` - */ -export function assertNotEquals( - actual: unknown, - expected: unknown, - msg?: string, -): void; -export function assertNotEquals(actual: T, expected: T, msg?: string): void; -export function assertNotEquals( - actual: unknown, - expected: unknown, - msg?: string, -): void { - if (!equal(actual, expected)) { - return; - } - let actualString: string; - let expectedString: string; - try { - actualString = String(actual); - } catch { - actualString = "[Cannot display]"; - } - try { - expectedString = String(expected); - } catch { - expectedString = "[Cannot display]"; - } - if (!msg) { - msg = `actual: ${actualString} expected: ${expectedString}`; - } - throw new AssertionError(msg); -} - -/** - * Make an assertion that `actual` and `expected` are strictly equal. If - * not then throw. - * ```ts - * assertStrictEquals(1, 2) - * ``` - */ -export function assertStrictEquals( - actual: unknown, - expected: unknown, - msg?: string, -): void; -export function assertStrictEquals( - actual: T, - expected: T, - msg?: string, -): void; -export function assertStrictEquals( - actual: unknown, - expected: unknown, - msg?: string, -): void { - if (actual === expected) { - return; - } - - let message: string; - - if (msg) { - message = msg; - } else { - const actualString = _format(actual); - const expectedString = _format(expected); - - if (actualString === expectedString) { - const withOffset = actualString - .split("\n") - .map((l) => ` ${l}`) - .join("\n"); - message = - `Values have the same structure but are not reference-equal:\n\n${ - red(withOffset) - }\n`; - } else { - try { - const diffResult = diff( - actualString.split("\n"), - expectedString.split("\n"), - ); - const diffMsg = buildMessage(diffResult).join("\n"); - message = `Values are not strictly equal:\n${diffMsg}`; - } catch { - message = `\n${red(CAN_NOT_DISPLAY)} + \n\n`; - } - } - } - - throw new AssertionError(message); -} - -/** - * Make an assertion that `actual` and `expected` are not strictly equal. - * If the values are strictly equal then throw. - * ```ts - * assertNotStrictEquals(1, 1) - * ``` - */ -export function assertNotStrictEquals( - actual: unknown, - expected: unknown, - msg?: string, -): void; -export function assertNotStrictEquals( - actual: T, - expected: T, - msg?: string, -): void; -export function assertNotStrictEquals( - actual: unknown, - expected: unknown, - msg?: string, -): void { - if (actual !== expected) { - return; - } - - throw new AssertionError( - msg ?? `Expected "actual" to be strictly unequal to: ${_format(actual)}\n`, - ); -} - -/** - * Make an assertion that actual is not null or undefined. If not - * then thrown. - */ -export function assertExists( - actual: unknown, - msg?: string, -): void { - if (actual === undefined || actual === null) { - if (!msg) { - msg = - `actual: "${actual}" expected to match anything but null or undefined`; - } - throw new AssertionError(msg); - } -} - -/** - * Make an assertion that actual includes expected. If not - * then thrown. - */ -export function assertStringIncludes( - actual: string, - expected: string, - msg?: string, -): void { - if (!actual.includes(expected)) { - if (!msg) { - msg = `actual: "${actual}" expected to contain: "${expected}"`; - } - throw new AssertionError(msg); - } -} - -/** - * Make an assertion that `actual` includes the `expected` values. - * If not then an error will be thrown. - * - * Type parameter can be specified to ensure values under comparison have the same type. - * For example: - *```ts - *assertArrayIncludes([1, 2], [2]) - *``` - */ -export function assertArrayIncludes( - actual: ArrayLike, - expected: ArrayLike, - msg?: string, -): void; -export function assertArrayIncludes( - actual: ArrayLike, - expected: ArrayLike, - msg?: string, -): void; -export function assertArrayIncludes( - actual: ArrayLike, - expected: ArrayLike, - msg?: string, -): void { - const missing: unknown[] = []; - for (let i = 0; i < expected.length; i++) { - let found = false; - for (let j = 0; j < actual.length; j++) { - if (equal(expected[i], actual[j])) { - found = true; - break; - } - } - if (!found) { - missing.push(expected[i]); - } - } - if (missing.length === 0) { - return; - } - if (!msg) { - msg = `actual: "${_format(actual)}" expected to include: "${ - _format(expected) - }"\nmissing: ${_format(missing)}`; - } - throw new AssertionError(msg); -} - -/** - * Make an assertion that `actual` match RegExp `expected`. If not - * then thrown - */ -export function assertMatch( - actual: string, - expected: RegExp, - msg?: string, -): void { - if (!expected.test(actual)) { - if (!msg) { - msg = `actual: "${actual}" expected to match: "${expected}"`; - } - throw new AssertionError(msg); - } -} - -/** - * Make an assertion that `actual` not match RegExp `expected`. If match - * then thrown - */ -export function assertNotMatch( - actual: string, - expected: RegExp, - msg?: string, -): void { - if (expected.test(actual)) { - if (!msg) { - msg = `actual: "${actual}" expected to not match: "${expected}"`; - } - throw new AssertionError(msg); - } -} - -/** - * Make an assertion that `actual` object is a subset of `expected` object, deeply. - * If not, then throw. - */ -export function assertObjectMatch( - actual: Record, - expected: Record, -): void { - type loose = Record; - const seen = new WeakMap(); - return assertEquals( - (function filter(a: loose, b: loose): loose { - // Prevent infinite loop with circular references with same filter - if ((seen.has(a)) && (seen.get(a) === b)) { - return a; - } - seen.set(a, b); - // Filter keys and symbols which are present in both actual and expected - const filtered = {} as loose; - const entries = [ - ...Object.getOwnPropertyNames(a), - ...Object.getOwnPropertySymbols(a), - ] - .filter((key) => key in b) - .map((key) => [key, a[key as string]]) as Array<[string, unknown]>; - // Build filtered object and filter recursively on nested objects references - for (const [key, value] of entries) { - if (typeof value === "object") { - const subset = (b as loose)[key]; - if ((typeof subset === "object") && (subset)) { - filtered[key] = filter(value as loose, subset as loose); - continue; - } - } - filtered[key] = value; - } - return filtered; - })(actual, expected), - expected, - ); -} - -/** - * Forcefully throws a failed assertion - */ -export function fail(msg?: string): void { - // eslint-disable-next-line @typescript-eslint/no-use-before-define - assert(false, `Failed assertion${msg ? `: ${msg}` : "."}`); -} - -/** - * Executes a function, expecting it to throw. If it does not, then it - * throws. An error class and a string that should be included in the - * error message can also be asserted. - */ -export function assertThrows( - fn: () => T, - ErrorClass?: Constructor, - msgIncludes = "", - msg?: string, -): Error { - let doesThrow = false; - let error = null; - try { - fn(); - } catch (e) { - if (e instanceof Error === false) { - throw new AssertionError("A non-Error object was thrown."); - } - if (ErrorClass && !(e instanceof ErrorClass)) { - msg = - `Expected error to be instance of "${ErrorClass.name}", but was "${e.constructor.name}"${ - msg ? `: ${msg}` : "." - }`; - throw new AssertionError(msg); - } - if ( - msgIncludes && - !stripColor(e.message).includes(stripColor(msgIncludes)) - ) { - msg = - `Expected error message to include "${msgIncludes}", but got "${e.message}"${ - msg ? `: ${msg}` : "." - }`; - throw new AssertionError(msg); - } - doesThrow = true; - error = e; - } - if (!doesThrow) { - msg = `Expected function to throw${msg ? `: ${msg}` : "."}`; - throw new AssertionError(msg); - } - return error; -} - -/** - * Executes a function which returns a promise, expecting it to throw or reject. - * If it does not, then it throws. An error class and a string that should be - * included in the error message can also be asserted. - */ -export async function assertThrowsAsync( - fn: () => Promise, - ErrorClass?: Constructor, - msgIncludes = "", - msg?: string, -): Promise { - let doesThrow = false; - let error = null; - try { - await fn(); - } catch (e) { - if (e instanceof Error === false) { - throw new AssertionError("A non-Error object was thrown or rejected."); - } - if (ErrorClass && !(e instanceof ErrorClass)) { - msg = - `Expected error to be instance of "${ErrorClass.name}", but got "${e.name}"${ - msg ? `: ${msg}` : "." - }`; - throw new AssertionError(msg); - } - if ( - msgIncludes && - !stripColor(e.message).includes(stripColor(msgIncludes)) - ) { - msg = - `Expected error message to include "${msgIncludes}", but got "${e.message}"${ - msg ? `: ${msg}` : "." - }`; - throw new AssertionError(msg); - } - doesThrow = true; - error = e; - } - if (!doesThrow) { - msg = `Expected function to throw${msg ? `: ${msg}` : "."}`; - throw new AssertionError(msg); - } - return error; -} - -/** Use this to stub out methods that will throw when invoked. */ -export function unimplemented(msg?: string): never { - throw new AssertionError(msg || "unimplemented"); -} - -/** Use this to assert unreachable code. */ -export function unreachable(): never { - throw new AssertionError("unreachable"); -} diff --git "a/.\\.cache/deps/https/deno.land/688e058fb547030f059b02f08b6bc2f36f15d56e6edb3bce6b48fdf563fb7ae9.metadata.json" "b/.\\.cache/deps/https/deno.land/688e058fb547030f059b02f08b6bc2f36f15d56e6edb3bce6b48fdf563fb7ae9.metadata.json" deleted file mode 100644 index b026e91..0000000 --- "a/.\\.cache/deps/https/deno.land/688e058fb547030f059b02f08b6bc2f36f15d56e6edb3bce6b48fdf563fb7ae9.metadata.json" +++ /dev/null @@ -1,27 +0,0 @@ -{ - "headers": { - "x-cache": "Hit from cloudfront", - "last-modified": "Tue, 09 Mar 2021 20:51:37 GMT", - "cache-control": "public, max-age=31536000, immutable", - "age": "1137010", - "accept-ranges": "bytes", - "x-amz-version-id": "QQviodBEowgXWHuH1TLYJlVV7Ut.ZGFX", - "server": "deno/asia-southeast1-a", - "content-security-policy": "default-src 'none'; style-src 'unsafe-inline'; sandbox", - "date": "Sun, 09 Oct 2022 06:32:40 GMT", - "access-control-allow-origin": "*", - "content-type": "application/typescript; charset=utf-8", - "x-amz-replication-status": "FAILED", - "via": "1.1 16074517396ff3ce754e4ac422c346c8.cloudfront.net (CloudFront)", - "x-amz-cf-pop": "SIN52-P1", - "x-amz-cf-id": "cup4KSozQRwMJeKCbi0ANqSPnuNhD_62fXhwFz44y1vIBcnJhdH3bw==", - "content-length": "15918", - "vary": "Accept-Encoding, Origin", - "etag": "\"8e6a8028df051e57f66135aca5bc9261\"" - }, - "url": "https://deno.land/std@0.90.0/testing/asserts.ts", - "now": { - "secs_since_epoch": 1666434170, - "nanos_since_epoch": 349336000 - } -} \ No newline at end of file diff --git "a/.\\.cache/deps/https/deno.land/7c02e05b5297e003cb3d3ca5a0297c761a2f3a683dbb03ff3a1380681fcb8d54" "b/.\\.cache/deps/https/deno.land/7c02e05b5297e003cb3d3ca5a0297c761a2f3a683dbb03ff3a1380681fcb8d54" deleted file mode 100644 index 45bd7b2..0000000 --- "a/.\\.cache/deps/https/deno.land/7c02e05b5297e003cb3d3ca5a0297c761a2f3a683dbb03ff3a1380681fcb8d54" +++ /dev/null @@ -1,930 +0,0 @@ -export class Tx { - type: number; - sender: string; - contractCall?: TxContractCall; - transferStx?: TxTransfer; - deployContract?: TxDeployContract; - - constructor(type: number, sender: string) { - this.type = type; - this.sender = sender; - } - - static transferSTX(amount: number, recipient: string, sender: string) { - let tx = new Tx(1, sender); - tx.transferStx = { - recipient, - amount, - }; - return tx; - } - - static contractCall( - contract: string, - method: string, - args: Array, - sender: string, - ) { - let tx = new Tx(2, sender); - tx.contractCall = { - contract, - method, - args, - }; - return tx; - } - - static deployContract(name: string, code: string, sender: string) { - let tx = new Tx(3, sender); - tx.deployContract = { - name, - code, - }; - return tx; - } -} - -export interface TxContractCall { - contract: string; - method: string; - args: Array; -} - -export interface TxDeployContract { - code: string; - name: string; -} - -export interface TxTransfer { - amount: number; - recipient: string; -} - -export interface TxReceipt { - result: string; - events: Array; -} - -export interface Block { - height: number; - receipts: Array; -} - -export interface Account { - address: string; - balance: number; - name: string; -} - -export interface Chain { - sessionId: number; -} - -export interface ReadOnlyFn { - session_id: number; - result: string; - events: Array; -} - -export interface EmptyBlock { - session_id: number; - block_height: number; -} - -export interface AssetsMaps { - session_id: number; - assets: { - [name: string]: { - [owner: string]: number; - }; - }; -} - -export class Chain { - sessionId: number; - blockHeight: number = 1; - - constructor(sessionId: number) { - this.sessionId = sessionId; - } - - mineBlock(transactions: Array): Block { - // @ts-ignore - let result = JSON.parse(Deno.core.opSync("api/v1/mine_block", { - sessionId: this.sessionId, - transactions: transactions, - })); - this.blockHeight = result.block_height; - let block: Block = { - height: result.block_height, - receipts: result.receipts, - }; - return block; - } - - mineEmptyBlock(count: number): EmptyBlock { - let result = JSON.parse( - // @ts-ignore - Deno.core.opSync("api/v1/mine_empty_blocks", { - sessionId: this.sessionId, - count: count, - }), - ); - this.blockHeight = result.block_height; - let emptyBlock: EmptyBlock = { - session_id: result.session_id, - block_height: result.block_height, - }; - return emptyBlock; - } - - mineEmptyBlockUntil(targetBlockHeight: number): EmptyBlock { - let count = targetBlockHeight - this.blockHeight; - if (count < 0) { - throw new Error( - `Chain tip cannot be moved from ${this.blockHeight} to ${targetBlockHeight}`, - ); - } - return this.mineEmptyBlock(count); - } - - callReadOnlyFn( - contract: string, - method: string, - args: Array, - sender: string, - ): ReadOnlyFn { - let result = JSON.parse( - // @ts-ignore - Deno.core.opSync("api/v1/call_read_only_fn", { - sessionId: this.sessionId, - contract: contract, - method: method, - args: args, - sender: sender, - }), - ); - let readOnlyFn: ReadOnlyFn = { - session_id: result.session_id, - result: result.result, - events: result.events, - }; - return readOnlyFn; - } - - getAssetsMaps(): AssetsMaps { - let result = JSON.parse( - // @ts-ignore - Deno.core.opSync("api/v1/get_assets_maps", { - sessionId: this.sessionId, - }), - ); - let assetsMaps: AssetsMaps = { - session_id: result.session_id, - assets: result.assets, - }; - return assetsMaps; - } -} - -type PreDeploymentFunction = ( - chain: Chain, - accounts: Map, -) => void | Promise; - -type TestFunction = ( - chain: Chain, - accounts: Map, - contracts: Map, -) => void | Promise; -type PreSetupFunction = () => Array; - -interface UnitTestOptions { - name: string; - only?: true; - ignore?: true; - deploymentPath?: string; - preDeployment?: PreDeploymentFunction; - fn: TestFunction; -} - -export interface Contract { - contract_id: string; - source: string; - contract_interface: any; -} - -export interface StacksNode { - url: string; -} - -type ScriptFunction = ( - accounts: Map, - contracts: Map, - node: StacksNode, -) => void | Promise; - -interface ScriptOptions { - fn: ScriptFunction; -} - -export class Clarinet { - static test(options: UnitTestOptions) { - // @ts-ignore - Deno.test({ - name: options.name, - only: options.only, - ignore: options.ignore, - async fn() { - let hasPreDeploymentSteps = options.preDeployment !== undefined; - - let result = JSON.parse( - // @ts-ignore - Deno.core.opSync("api/v1/new_session", { - name: options.name, - loadDeployment: !hasPreDeploymentSteps, - deploymentPath: options.deploymentPath, - }), - ); - - if (options.preDeployment) { - let chain = new Chain(result["session_id"]); - let accounts: Map = new Map(); - for (let account of result["accounts"]) { - accounts.set(account.name, account); - } - await options.preDeployment(chain, accounts); - - result = JSON.parse( - // @ts-ignore - Deno.core.opSync("api/v1/load_deployment", { - sessionId: chain.sessionId, - deploymentPath: options.deploymentPath, - }), - ); - } - - let chain = new Chain(result["session_id"]); - let accounts: Map = new Map(); - for (let account of result["accounts"]) { - accounts.set(account.name, account); - } - let contracts: Map = new Map(); - for (let contract of result["contracts"]) { - contracts.set(contract.contract_id, contract); - } - await options.fn(chain, accounts, contracts); - - // @ts-ignore - JSON.parse(Deno.core.opSync("api/v1/terminate_session", { - sessionId: chain.sessionId, - })); - }, - }); - } - - static run(options: ScriptOptions) { - // @ts-ignore - Deno.test({ - name: "running script", - async fn() { - let result = JSON.parse( - // @ts-ignore - Deno.core.opSync("api/v1/new_session", { - name: "running script", - loadDeployment: true, - deploymentPath: undefined, - }), - ); - let accounts: Map = new Map(); - for (let account of result["accounts"]) { - accounts.set(account.name, account); - } - let contracts: Map = new Map(); - for (let contract of result["contracts"]) { - contracts.set(contract.contract_id, contract); - } - let stacks_node: StacksNode = { - url: result["stacks_node_url"], - }; - await options.fn(accounts, contracts, stacks_node); - }, - }); - } -} - -export namespace types { - const byteToHex: any = []; - for (let n = 0; n <= 0xff; ++n) { - const hexOctet = n.toString(16).padStart(2, "0"); - byteToHex.push(hexOctet); - } - - function serializeTuple(input: Object) { - let items: Array = []; - for (var [key, value] of Object.entries(input)) { - if (typeof value === "object") { - items.push(`${key}: { ${serializeTuple(value)} }`); - } else if (Array.isArray(value)) { - // todo(ludo): not supported, should panic - } else { - items.push(`${key}: ${value}`); - } - } - return items.join(", "); - } - - function isObject(obj: any) { - return typeof obj === "object" && !Array.isArray(obj); - } - - export function ok(val: string) { - return `(ok ${val})`; - } - - export function err(val: string) { - return `(err ${val})`; - } - - export function some(val: string) { - return `(some ${val})`; - } - - export function none() { - return `none`; - } - - export function bool(val: boolean) { - return `${val}`; - } - - export function int(val: number | bigint) { - return `${val}`; - } - - export function uint(val: number | bigint) { - return `u${val}`; - } - - export function ascii(val: string) { - return JSON.stringify(val); - } - - export function utf8(val: string) { - return `u${JSON.stringify(val)}`; - } - - export function buff(val: ArrayBuffer | string) { - const buff = typeof val == "string" - ? new TextEncoder().encode(val) - : new Uint8Array(val); - - const hexOctets = new Array(buff.length); - - for (let i = 0; i < buff.length; ++i) { - hexOctets[i] = byteToHex[buff[i]]; - } - - return `0x${hexOctets.join("")}`; - } - - export function list(val: Array) { - return `(list ${val.join(" ")})`; - } - - export function principal(val: string) { - return `'${val}`; - } - - export function tuple(val: Object) { - return `{ ${serializeTuple(val)} }`; - } -} - -declare global { - interface String { - expectOk(): String; - expectErr(): String; - expectSome(): String; - expectNone(): void; - expectBool(value: boolean): boolean; - expectUint(value: number | bigint): bigint; - expectInt(value: number | bigint): bigint; - expectBuff(value: ArrayBuffer): ArrayBuffer; - expectAscii(value: String): String; - expectUtf8(value: String): String; - expectPrincipal(value: String): String; - expectList(): Array; - expectTuple(): Record; - } - - interface Array { - expectSTXTransferEvent( - amount: Number | bigint, - sender: String, - recipient: String, - ): Object; - expectFungibleTokenTransferEvent( - amount: Number | bigint, - sender: String, - recipient: String, - assetId: String, - ): Object; - expectFungibleTokenMintEvent( - amount: Number | bigint, - recipient: String, - assetId: String, - ): Object; - expectFungibleTokenBurnEvent( - amount: Number | bigint, - sender: String, - assetId: String, - ): Object; - expectPrintEvent( - contract_identifier: string, - value: string, - ): Object; - expectNonFungibleTokenTransferEvent( - tokenId: String, - sender: String, - recipient: String, - assetAddress: String, - assetId: String, - ): Object; - expectNonFungibleTokenMintEvent( - tokenId: String, - recipient: String, - assetAddress: String, - assetId: String, - ): Object; - expectNonFungibleTokenBurnEvent( - tokenId: String, - sender: String, - assetAddress: String, - assetId: String, - ): Object; - // expectEvent(sel: (e: Object) => Object): Object; - } -} - -function consume(src: String, expectation: String, wrapped: boolean) { - let dst = (" " + src).slice(1); - let size = expectation.length; - if (!wrapped && src !== expectation) { - throw new Error( - `Expected ${green(expectation.toString())}, got ${red(src.toString())}`, - ); - } - if (wrapped) { - size += 2; - } - if (dst.length < size) { - throw new Error( - `Expected ${green(expectation.toString())}, got ${red(src.toString())}`, - ); - } - if (wrapped) { - dst = dst.substring(1, dst.length - 1); - } - let res = dst.slice(0, expectation.length); - if (res !== expectation) { - throw new Error( - `Expected ${green(expectation.toString())}, got ${red(src.toString())}`, - ); - } - let leftPad = 0; - if (dst.charAt(expectation.length) === " ") { - leftPad = 1; - } - let remainder = dst.substring(expectation.length + leftPad); - return remainder; -} - -String.prototype.expectOk = function () { - return consume(this, "ok", true); -}; - -String.prototype.expectErr = function () { - return consume(this, "err", true); -}; - -String.prototype.expectSome = function () { - return consume(this, "some", true); -}; - -String.prototype.expectNone = function () { - return consume(this, "none", false); -}; - -String.prototype.expectBool = function (value: boolean) { - try { - consume(this, `${value}`, false); - } catch (error) { - throw error; - } - return value; -}; - -String.prototype.expectUint = function (value: number | bigint): bigint { - try { - consume(this, `u${value}`, false); - } catch (error) { - throw error; - } - return BigInt(value); -}; - -String.prototype.expectInt = function (value: number | bigint): bigint { - try { - consume(this, `${value}`, false); - } catch (error) { - throw error; - } - return BigInt(value); -}; - -String.prototype.expectBuff = function (value: ArrayBuffer) { - let buffer = types.buff(value); - if (this !== buffer) { - throw new Error(`Expected ${green(buffer)}, got ${red(this.toString())}`); - } - return value; -}; - -String.prototype.expectAscii = function (value: string) { - try { - consume(this, `"${value}"`, false); - } catch (error) { - throw error; - } - return value; -}; - -String.prototype.expectUtf8 = function (value: string) { - try { - consume(this, `u"${value}"`, false); - } catch (error) { - throw error; - } - return value; -}; - -String.prototype.expectPrincipal = function (value: string) { - try { - consume(this, `${value}`, false); - } catch (error) { - throw error; - } - return value; -}; - -String.prototype.expectList = function () { - if (this.charAt(0) !== "[" || this.charAt(this.length - 1) !== "]") { - throw new Error( - `Expected ${green("(list ...)")}, got ${red(this.toString())}`, - ); - } - - let stack = []; - let elements = []; - let start = 1; - for (var i = 0; i < this.length; i++) { - if (this.charAt(i) === "," && stack.length == 1) { - elements.push(this.substring(start, i)); - start = i + 2; - } - if (["(", "[", "{"].includes(this.charAt(i))) { - stack.push(this.charAt(i)); - } - if (this.charAt(i) === ")" && stack[stack.length - 1] === "(") { - stack.pop(); - } - if (this.charAt(i) === "}" && stack[stack.length - 1] === "{") { - stack.pop(); - } - if (this.charAt(i) === "]" && stack[stack.length - 1] === "[") { - stack.pop(); - } - } - let remainder = this.substring(start, this.length - 1); - if (remainder.length > 0) { - elements.push(remainder); - } - return elements; -}; - -String.prototype.expectTuple = function () { - if (this.charAt(0) !== "{" || this.charAt(this.length - 1) !== "}") { - throw new Error( - `Expected ${green("(tuple ...)")}, got ${red(this.toString())}`, - ); - } - - let start = 1; - let stack = []; - let elements = []; - for (var i = 0; i < this.length; i++) { - if (this.charAt(i) === "," && stack.length == 1) { - elements.push(this.substring(start, i)); - start = i + 2; - } - if (["(", "[", "{"].includes(this.charAt(i))) { - stack.push(this.charAt(i)); - } - if (this.charAt(i) === ")" && stack[stack.length - 1] === "(") { - stack.pop(); - } - if (this.charAt(i) === "}" && stack[stack.length - 1] === "{") { - stack.pop(); - } - if (this.charAt(i) === "]" && stack[stack.length - 1] === "[") { - stack.pop(); - } - } - let remainder = this.substring(start, this.length - 1); - if (remainder.length > 0) { - elements.push(remainder); - } - - let tuple: Record = {}; - for (let element of elements) { - for (var i = 0; i < element.length; i++) { - if (element.charAt(i) === ":") { - let key: string = element.substring(0, i); - let value: string = element.substring(i + 2, element.length); - tuple[key] = value; - break; - } - } - } - - return tuple; -}; - -Array.prototype.expectSTXTransferEvent = function ( - amount: Number | bigint, - sender: String, - recipient: String, -) { - for (let event of this) { - try { - let e: any = {}; - e["amount"] = event.stx_transfer_event.amount.expectInt(amount); - e["sender"] = event.stx_transfer_event.sender.expectPrincipal(sender); - e["recipient"] = event.stx_transfer_event.recipient.expectPrincipal( - recipient, - ); - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected STXTransferEvent`); -}; - -Array.prototype.expectFungibleTokenTransferEvent = function ( - amount: Number, - sender: String, - recipient: String, - assetId: String, -) { - for (let event of this) { - try { - let e: any = {}; - e["amount"] = event.ft_transfer_event.amount.expectInt(amount); - e["sender"] = event.ft_transfer_event.sender.expectPrincipal(sender); - e["recipient"] = event.ft_transfer_event.recipient.expectPrincipal( - recipient, - ); - if (event.ft_transfer_event.asset_identifier.endsWith(assetId)) { - e["assetId"] = event.ft_transfer_event.asset_identifier; - } else { - continue; - } - return e; - } catch (error) { - continue; - } - } - throw new Error( - `Unable to retrieve expected FungibleTokenTransferEvent(${amount}, ${sender}, ${recipient}, ${assetId})\n${ - JSON.stringify(this) - }`, - ); -}; - -Array.prototype.expectFungibleTokenMintEvent = function ( - amount: Number | bigint, - recipient: String, - assetId: String, -) { - for (let event of this) { - try { - let e: any = {}; - e["amount"] = event.ft_mint_event.amount.expectInt(amount); - e["recipient"] = event.ft_mint_event.recipient.expectPrincipal(recipient); - if (event.ft_mint_event.asset_identifier.endsWith(assetId)) { - e["assetId"] = event.ft_mint_event.asset_identifier; - } else { - continue; - } - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected FungibleTokenMintEvent`); -}; - -Array.prototype.expectFungibleTokenBurnEvent = function ( - amount: Number | bigint, - sender: String, - assetId: String, -) { - for (let event of this) { - try { - let e: any = {}; - e["amount"] = event.ft_burn_event.amount.expectInt(amount); - e["sender"] = event.ft_burn_event.sender.expectPrincipal(sender); - if (event.ft_burn_event.asset_identifier.endsWith(assetId)) { - e["assetId"] = event.ft_burn_event.asset_identifier; - } else { - continue; - } - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected FungibleTokenBurnEvent`); -}; - -Array.prototype.expectPrintEvent = function ( - contract_identifier: string, - value: string, -) { - for (let event of this) { - try { - let e: any = {}; - e["contract_identifier"] = event.contract_event.contract_identifier - .expectPrincipal( - contract_identifier, - ); - - if (event.contract_event.topic.endsWith("print")) { - e["topic"] = event.contract_event.topic; - } else { - continue; - } - - if (event.contract_event.value.endsWith(value)) { - e["value"] = event.contract_event.value; - } else { - continue; - } - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected PrintEvent`); -}; -// Array.prototype.expectEvent = function(sel: (e: Object) => Object) { -// for (let event of this) { -// try { -// sel(event); -// return event as Object; -// } catch (error) { -// continue; -// } -// } -// throw new Error(`Unable to retrieve expected PrintEvent`); -// } -Array.prototype.expectNonFungibleTokenTransferEvent = function ( - tokenId: String, - sender: String, - recipient: String, - assetAddress: String, - assetId: String, -) { - for (let event of this) { - try { - let e: any = {}; - if (event.nft_transfer_event.value === tokenId) { - e["tokenId"] = event.nft_transfer_event.value; - } else { - continue; - } - e["sender"] = event.nft_transfer_event.sender.expectPrincipal(sender); - e["recipient"] = event.nft_transfer_event.recipient.expectPrincipal( - recipient, - ); - if ( - event.nft_transfer_event.asset_identifier === - `${assetAddress}::${assetId}` - ) { - e["assetId"] = event.nft_transfer_event.asset_identifier; - } else { - continue; - } - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected NonFungibleTokenTransferEvent`); -}; - -Array.prototype.expectNonFungibleTokenMintEvent = function ( - tokenId: String, - recipient: String, - assetAddress: String, - assetId: String, -) { - for (let event of this) { - try { - let e: any = {}; - if (event.nft_mint_event.value === tokenId) { - e["tokenId"] = event.nft_mint_event.value; - } else { - continue; - } - e["recipient"] = event.nft_mint_event.recipient.expectPrincipal( - recipient, - ); - if ( - event.nft_mint_event.asset_identifier === `${assetAddress}::${assetId}` - ) { - e["assetId"] = event.nft_mint_event.asset_identifier; - } else { - continue; - } - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected NonFungibleTokenMintEvent`); -}; - -Array.prototype.expectNonFungibleTokenBurnEvent = function ( - tokenId: String, - sender: String, - assetAddress: String, - assetId: String, -) { - for (let event of this) { - try { - let e: any = {}; - if (event.nft_burn_event.value === tokenId) { - e["tokenId"] = event.nft_burn_event.value; - } else { - continue; - } - e["sender"] = event.nft_burn_event.sender.expectPrincipal(sender); - if ( - event.nft_burn_event.asset_identifier === `${assetAddress}::${assetId}` - ) { - e["assetId"] = event.nft_burn_event.asset_identifier; - } else { - continue; - } - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected NonFungibleTokenBurnEvent`); -}; - -const noColor = globalThis.Deno?.noColor ?? true; - -interface Code { - open: string; - close: string; - regexp: RegExp; -} - -let enabled = !noColor; - -function code(open: number[], close: number): Code { - return { - open: `\x1b[${open.join(";")}m`, - close: `\x1b[${close}m`, - regexp: new RegExp(`\\x1b\\[${close}m`, "g"), - }; -} - -function run(str: string, code: Code): string { - return enabled - ? `${code.open}${str.replace(code.regexp, code.open)}${code.close}` - : str; -} - -export function red(str: string): string { - return run(str, code([31], 39)); -} - -export function green(str: string): string { - return run(str, code([32], 39)); -} diff --git "a/.\\.cache/deps/https/deno.land/7c02e05b5297e003cb3d3ca5a0297c761a2f3a683dbb03ff3a1380681fcb8d54.metadata.json" "b/.\\.cache/deps/https/deno.land/7c02e05b5297e003cb3d3ca5a0297c761a2f3a683dbb03ff3a1380681fcb8d54.metadata.json" deleted file mode 100644 index 119f077..0000000 --- "a/.\\.cache/deps/https/deno.land/7c02e05b5297e003cb3d3ca5a0297c761a2f3a683dbb03ff3a1380681fcb8d54.metadata.json" +++ /dev/null @@ -1,27 +0,0 @@ -{ - "headers": { - "last-modified": "Sat, 08 Oct 2022 16:33:01 GMT", - "content-security-policy": "default-src 'none'; style-src 'unsafe-inline'; sandbox", - "content-length": "22514", - "server": "deno/asia-southeast1-a", - "x-amz-cf-id": "cyZOp3MnwRzi2QvqCsAu3eQCn1CBgZzIVgy9TdMDCuVi94Xw8tlFfA==", - "etag": "\"c7c259520f5cc5747ec5076b8bb7daf0\"", - "x-amz-cf-pop": "SIN52-P1", - "x-amz-replication-status": "COMPLETED", - "cache-control": "public, max-age=31536000, immutable", - "x-amz-version-id": "9Xz24YLsKxzQ7DI7YgdrvY_CNSjrcVap", - "age": "861837", - "date": "Wed, 12 Oct 2022 10:58:54 GMT", - "via": "1.1 16074517396ff3ce754e4ac422c346c8.cloudfront.net (CloudFront)", - "access-control-allow-origin": "*", - "x-cache": "Hit from cloudfront", - "content-type": "application/typescript; charset=utf-8", - "vary": "Accept-Encoding, Origin", - "accept-ranges": "bytes" - }, - "url": "https://deno.land/x/clarinet@v1.0.2/index.ts", - "now": { - "secs_since_epoch": 1666434170, - "nanos_since_epoch": 330218000 - } -} \ No newline at end of file diff --git "a/.\\.cache/deps/https/deno.land/b74532b63b4b2b08e618f6ccbb6ec181293852d7b2c4aea34cb1599ab82741d4" "b/.\\.cache/deps/https/deno.land/b74532b63b4b2b08e618f6ccbb6ec181293852d7b2c4aea34cb1599ab82741d4" deleted file mode 100644 index 7d659ac..0000000 --- "a/.\\.cache/deps/https/deno.land/b74532b63b4b2b08e618f6ccbb6ec181293852d7b2c4aea34cb1599ab82741d4" +++ /dev/null @@ -1,228 +0,0 @@ -// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. -// This module is browser compatible. - -interface FarthestPoint { - y: number; - id: number; -} - -export enum DiffType { - removed = "removed", - common = "common", - added = "added", -} - -export interface DiffResult { - type: DiffType; - value: T; -} - -const REMOVED = 1; -const COMMON = 2; -const ADDED = 3; - -function createCommon(A: T[], B: T[], reverse?: boolean): T[] { - const common = []; - if (A.length === 0 || B.length === 0) return []; - for (let i = 0; i < Math.min(A.length, B.length); i += 1) { - if ( - A[reverse ? A.length - i - 1 : i] === B[reverse ? B.length - i - 1 : i] - ) { - common.push(A[reverse ? A.length - i - 1 : i]); - } else { - return common; - } - } - return common; -} - -/** - * Renders the differences between the actual and expected values - * @param A Actual value - * @param B Expected value - */ -export function diff(A: T[], B: T[]): Array> { - const prefixCommon = createCommon(A, B); - const suffixCommon = createCommon( - A.slice(prefixCommon.length), - B.slice(prefixCommon.length), - true, - ).reverse(); - A = suffixCommon.length - ? A.slice(prefixCommon.length, -suffixCommon.length) - : A.slice(prefixCommon.length); - B = suffixCommon.length - ? B.slice(prefixCommon.length, -suffixCommon.length) - : B.slice(prefixCommon.length); - const swapped = B.length > A.length; - [A, B] = swapped ? [B, A] : [A, B]; - const M = A.length; - const N = B.length; - if (!M && !N && !suffixCommon.length && !prefixCommon.length) return []; - if (!N) { - return [ - ...prefixCommon.map( - (c): DiffResult => ({ type: DiffType.common, value: c }), - ), - ...A.map( - (a): DiffResult => ({ - type: swapped ? DiffType.added : DiffType.removed, - value: a, - }), - ), - ...suffixCommon.map( - (c): DiffResult => ({ type: DiffType.common, value: c }), - ), - ]; - } - const offset = N; - const delta = M - N; - const size = M + N + 1; - const fp = new Array(size).fill({ y: -1 }); - /** - * INFO: - * This buffer is used to save memory and improve performance. - * The first half is used to save route and last half is used to save diff - * type. - * This is because, when I kept new uint8array area to save type,performance - * worsened. - */ - const routes = new Uint32Array((M * N + size + 1) * 2); - const diffTypesPtrOffset = routes.length / 2; - let ptr = 0; - let p = -1; - - function backTrace( - A: T[], - B: T[], - current: FarthestPoint, - swapped: boolean, - ): Array<{ - type: DiffType; - value: T; - }> { - const M = A.length; - const N = B.length; - const result = []; - let a = M - 1; - let b = N - 1; - let j = routes[current.id]; - let type = routes[current.id + diffTypesPtrOffset]; - while (true) { - if (!j && !type) break; - const prev = j; - if (type === REMOVED) { - result.unshift({ - type: swapped ? DiffType.removed : DiffType.added, - value: B[b], - }); - b -= 1; - } else if (type === ADDED) { - result.unshift({ - type: swapped ? DiffType.added : DiffType.removed, - value: A[a], - }); - a -= 1; - } else { - result.unshift({ type: DiffType.common, value: A[a] }); - a -= 1; - b -= 1; - } - j = routes[prev]; - type = routes[prev + diffTypesPtrOffset]; - } - return result; - } - - function createFP( - slide: FarthestPoint, - down: FarthestPoint, - k: number, - M: number, - ): FarthestPoint { - if (slide && slide.y === -1 && down && down.y === -1) { - return { y: 0, id: 0 }; - } - if ( - (down && down.y === -1) || - k === M || - (slide && slide.y) > (down && down.y) + 1 - ) { - const prev = slide.id; - ptr++; - routes[ptr] = prev; - routes[ptr + diffTypesPtrOffset] = ADDED; - return { y: slide.y, id: ptr }; - } else { - const prev = down.id; - ptr++; - routes[ptr] = prev; - routes[ptr + diffTypesPtrOffset] = REMOVED; - return { y: down.y + 1, id: ptr }; - } - } - - function snake( - k: number, - slide: FarthestPoint, - down: FarthestPoint, - _offset: number, - A: T[], - B: T[], - ): FarthestPoint { - const M = A.length; - const N = B.length; - if (k < -N || M < k) return { y: -1, id: -1 }; - const fp = createFP(slide, down, k, M); - while (fp.y + k < M && fp.y < N && A[fp.y + k] === B[fp.y]) { - const prev = fp.id; - ptr++; - fp.id = ptr; - fp.y += 1; - routes[ptr] = prev; - routes[ptr + diffTypesPtrOffset] = COMMON; - } - return fp; - } - - while (fp[delta + offset].y < N) { - p = p + 1; - for (let k = -p; k < delta; ++k) { - fp[k + offset] = snake( - k, - fp[k - 1 + offset], - fp[k + 1 + offset], - offset, - A, - B, - ); - } - for (let k = delta + p; k > delta; --k) { - fp[k + offset] = snake( - k, - fp[k - 1 + offset], - fp[k + 1 + offset], - offset, - A, - B, - ); - } - fp[delta + offset] = snake( - delta, - fp[delta - 1 + offset], - fp[delta + 1 + offset], - offset, - A, - B, - ); - } - return [ - ...prefixCommon.map( - (c): DiffResult => ({ type: DiffType.common, value: c }), - ), - ...backTrace(A, B, fp[delta + offset], swapped), - ...suffixCommon.map( - (c): DiffResult => ({ type: DiffType.common, value: c }), - ), - ]; -} diff --git "a/.\\.cache/deps/https/deno.land/b74532b63b4b2b08e618f6ccbb6ec181293852d7b2c4aea34cb1599ab82741d4.metadata.json" "b/.\\.cache/deps/https/deno.land/b74532b63b4b2b08e618f6ccbb6ec181293852d7b2c4aea34cb1599ab82741d4.metadata.json" deleted file mode 100644 index 6e92308..0000000 --- "a/.\\.cache/deps/https/deno.land/b74532b63b4b2b08e618f6ccbb6ec181293852d7b2c4aea34cb1599ab82741d4.metadata.json" +++ /dev/null @@ -1,27 +0,0 @@ -{ - "headers": { - "access-control-allow-origin": "*", - "cache-control": "public, max-age=31536000, immutable", - "x-amz-replication-status": "FAILED", - "date": "Tue, 06 Sep 2022 09:49:37 GMT", - "etag": "\"8bbb088bc30795a6cd6fcfed40215aea\"", - "content-type": "application/typescript; charset=utf-8", - "x-amz-cf-pop": "SIN52-P1", - "x-amz-version-id": "FrMfK5wXDicXK1HncSFcPESiVr7SNOSg", - "content-length": "5587", - "x-amz-cf-id": "ceb2U1a5nxwoVqmPJcwk21tbmD7zZyoa8iEXwEhQI3IdyMKcLMya4g==", - "server": "deno/asia-southeast1-a", - "content-security-policy": "default-src 'none'; style-src 'unsafe-inline'; sandbox", - "x-cache": "Hit from cloudfront", - "age": "3976394", - "vary": "Accept-Encoding, Origin", - "via": "1.1 16074517396ff3ce754e4ac422c346c8.cloudfront.net (CloudFront)", - "accept-ranges": "bytes", - "last-modified": "Tue, 09 Mar 2021 20:51:37 GMT" - }, - "url": "https://deno.land/std@0.90.0/testing/_diff.ts", - "now": { - "secs_since_epoch": 1666434170, - "nanos_since_epoch": 442025000 - } -} \ No newline at end of file diff --git "a/.\\.cache/deps/https/deno.land/c3031fe6d1ec46c7ee6519cd64b11875eca3b83ce3ceb1323a43a0810846f180" "b/.\\.cache/deps/https/deno.land/c3031fe6d1ec46c7ee6519cd64b11875eca3b83ce3ceb1323a43a0810846f180" deleted file mode 100644 index f283bd2..0000000 --- "a/.\\.cache/deps/https/deno.land/c3031fe6d1ec46c7ee6519cd64b11875eca3b83ce3ceb1323a43a0810846f180" +++ /dev/null @@ -1,522 +0,0 @@ -// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. -// A module to print ANSI terminal colors. Inspired by chalk, kleur, and colors -// on npm. -// -// ``` -// import { bgBlue, red, bold } from "https://deno.land/std/fmt/colors.ts"; -// console.log(bgBlue(red(bold("Hello world!")))); -// ``` -// -// This module supports `NO_COLOR` environmental variable disabling any coloring -// if `NO_COLOR` is set. -// -// This module is browser compatible. - -const noColor = globalThis.Deno?.noColor ?? true; - -interface Code { - open: string; - close: string; - regexp: RegExp; -} - -/** RGB 8-bits per channel. Each in range `0->255` or `0x00->0xff` */ -interface Rgb { - r: number; - g: number; - b: number; -} - -let enabled = !noColor; - -/** - * Set changing text color to enabled or disabled - * @param value - */ -export function setColorEnabled(value: boolean): void { - if (noColor) { - return; - } - - enabled = value; -} - -/** Get whether text color change is enabled or disabled. */ -export function getColorEnabled(): boolean { - return enabled; -} - -/** - * Builds color code - * @param open - * @param close - */ -function code(open: number[], close: number): Code { - return { - open: `\x1b[${open.join(";")}m`, - close: `\x1b[${close}m`, - regexp: new RegExp(`\\x1b\\[${close}m`, "g"), - }; -} - -/** - * Applies color and background based on color code and its associated text - * @param str text to apply color settings to - * @param code color code to apply - */ -function run(str: string, code: Code): string { - return enabled - ? `${code.open}${str.replace(code.regexp, code.open)}${code.close}` - : str; -} - -/** - * Reset the text modified - * @param str text to reset - */ -export function reset(str: string): string { - return run(str, code([0], 0)); -} - -/** - * Make the text bold. - * @param str text to make bold - */ -export function bold(str: string): string { - return run(str, code([1], 22)); -} - -/** - * The text emits only a small amount of light. - * @param str text to dim - */ -export function dim(str: string): string { - return run(str, code([2], 22)); -} - -/** - * Make the text italic. - * @param str text to make italic - */ -export function italic(str: string): string { - return run(str, code([3], 23)); -} - -/** - * Make the text underline. - * @param str text to underline - */ -export function underline(str: string): string { - return run(str, code([4], 24)); -} - -/** - * Invert background color and text color. - * @param str text to invert its color - */ -export function inverse(str: string): string { - return run(str, code([7], 27)); -} - -/** - * Make the text hidden. - * @param str text to hide - */ -export function hidden(str: string): string { - return run(str, code([8], 28)); -} - -/** - * Put horizontal line through the center of the text. - * @param str text to strike through - */ -export function strikethrough(str: string): string { - return run(str, code([9], 29)); -} - -/** - * Set text color to black. - * @param str text to make black - */ -export function black(str: string): string { - return run(str, code([30], 39)); -} - -/** - * Set text color to red. - * @param str text to make red - */ -export function red(str: string): string { - return run(str, code([31], 39)); -} - -/** - * Set text color to green. - * @param str text to make green - */ -export function green(str: string): string { - return run(str, code([32], 39)); -} - -/** - * Set text color to yellow. - * @param str text to make yellow - */ -export function yellow(str: string): string { - return run(str, code([33], 39)); -} - -/** - * Set text color to blue. - * @param str text to make blue - */ -export function blue(str: string): string { - return run(str, code([34], 39)); -} - -/** - * Set text color to magenta. - * @param str text to make magenta - */ -export function magenta(str: string): string { - return run(str, code([35], 39)); -} - -/** - * Set text color to cyan. - * @param str text to make cyan - */ -export function cyan(str: string): string { - return run(str, code([36], 39)); -} - -/** - * Set text color to white. - * @param str text to make white - */ -export function white(str: string): string { - return run(str, code([37], 39)); -} - -/** - * Set text color to gray. - * @param str text to make gray - */ -export function gray(str: string): string { - return brightBlack(str); -} - -/** - * Set text color to bright black. - * @param str text to make bright-black - */ -export function brightBlack(str: string): string { - return run(str, code([90], 39)); -} - -/** - * Set text color to bright red. - * @param str text to make bright-red - */ -export function brightRed(str: string): string { - return run(str, code([91], 39)); -} - -/** - * Set text color to bright green. - * @param str text to make bright-green - */ -export function brightGreen(str: string): string { - return run(str, code([92], 39)); -} - -/** - * Set text color to bright yellow. - * @param str text to make bright-yellow - */ -export function brightYellow(str: string): string { - return run(str, code([93], 39)); -} - -/** - * Set text color to bright blue. - * @param str text to make bright-blue - */ -export function brightBlue(str: string): string { - return run(str, code([94], 39)); -} - -/** - * Set text color to bright magenta. - * @param str text to make bright-magenta - */ -export function brightMagenta(str: string): string { - return run(str, code([95], 39)); -} - -/** - * Set text color to bright cyan. - * @param str text to make bright-cyan - */ -export function brightCyan(str: string): string { - return run(str, code([96], 39)); -} - -/** - * Set text color to bright white. - * @param str text to make bright-white - */ -export function brightWhite(str: string): string { - return run(str, code([97], 39)); -} - -/** - * Set background color to black. - * @param str text to make its background black - */ -export function bgBlack(str: string): string { - return run(str, code([40], 49)); -} - -/** - * Set background color to red. - * @param str text to make its background red - */ -export function bgRed(str: string): string { - return run(str, code([41], 49)); -} - -/** - * Set background color to green. - * @param str text to make its background green - */ -export function bgGreen(str: string): string { - return run(str, code([42], 49)); -} - -/** - * Set background color to yellow. - * @param str text to make its background yellow - */ -export function bgYellow(str: string): string { - return run(str, code([43], 49)); -} - -/** - * Set background color to blue. - * @param str text to make its background blue - */ -export function bgBlue(str: string): string { - return run(str, code([44], 49)); -} - -/** - * Set background color to magenta. - * @param str text to make its background magenta - */ -export function bgMagenta(str: string): string { - return run(str, code([45], 49)); -} - -/** - * Set background color to cyan. - * @param str text to make its background cyan - */ -export function bgCyan(str: string): string { - return run(str, code([46], 49)); -} - -/** - * Set background color to white. - * @param str text to make its background white - */ -export function bgWhite(str: string): string { - return run(str, code([47], 49)); -} - -/** - * Set background color to bright black. - * @param str text to make its background bright-black - */ -export function bgBrightBlack(str: string): string { - return run(str, code([100], 49)); -} - -/** - * Set background color to bright red. - * @param str text to make its background bright-red - */ -export function bgBrightRed(str: string): string { - return run(str, code([101], 49)); -} - -/** - * Set background color to bright green. - * @param str text to make its background bright-green - */ -export function bgBrightGreen(str: string): string { - return run(str, code([102], 49)); -} - -/** - * Set background color to bright yellow. - * @param str text to make its background bright-yellow - */ -export function bgBrightYellow(str: string): string { - return run(str, code([103], 49)); -} - -/** - * Set background color to bright blue. - * @param str text to make its background bright-blue - */ -export function bgBrightBlue(str: string): string { - return run(str, code([104], 49)); -} - -/** - * Set background color to bright magenta. - * @param str text to make its background bright-magenta - */ -export function bgBrightMagenta(str: string): string { - return run(str, code([105], 49)); -} - -/** - * Set background color to bright cyan. - * @param str text to make its background bright-cyan - */ -export function bgBrightCyan(str: string): string { - return run(str, code([106], 49)); -} - -/** - * Set background color to bright white. - * @param str text to make its background bright-white - */ -export function bgBrightWhite(str: string): string { - return run(str, code([107], 49)); -} - -/* Special Color Sequences */ - -/** - * Clam and truncate color codes - * @param n - * @param max number to truncate to - * @param min number to truncate from - */ -function clampAndTruncate(n: number, max = 255, min = 0): number { - return Math.trunc(Math.max(Math.min(n, max), min)); -} - -/** - * Set text color using paletted 8bit colors. - * https://en.wikipedia.org/wiki/ANSI_escape_code#8-bit - * @param str text color to apply paletted 8bit colors to - * @param color code - */ -export function rgb8(str: string, color: number): string { - return run(str, code([38, 5, clampAndTruncate(color)], 39)); -} - -/** - * Set background color using paletted 8bit colors. - * https://en.wikipedia.org/wiki/ANSI_escape_code#8-bit - * @param str text color to apply paletted 8bit background colors to - * @param color code - */ -export function bgRgb8(str: string, color: number): string { - return run(str, code([48, 5, clampAndTruncate(color)], 49)); -} - -/** - * Set text color using 24bit rgb. - * `color` can be a number in range `0x000000` to `0xffffff` or - * an `Rgb`. - * - * To produce the color magenta: - * - * rgb24("foo", 0xff00ff); - * rgb24("foo", {r: 255, g: 0, b: 255}); - * @param str text color to apply 24bit rgb to - * @param color code - */ -export function rgb24(str: string, color: number | Rgb): string { - if (typeof color === "number") { - return run( - str, - code( - [38, 2, (color >> 16) & 0xff, (color >> 8) & 0xff, color & 0xff], - 39, - ), - ); - } - return run( - str, - code( - [ - 38, - 2, - clampAndTruncate(color.r), - clampAndTruncate(color.g), - clampAndTruncate(color.b), - ], - 39, - ), - ); -} - -/** - * Set background color using 24bit rgb. - * `color` can be a number in range `0x000000` to `0xffffff` or - * an `Rgb`. - * - * To produce the color magenta: - * - * bgRgb24("foo", 0xff00ff); - * bgRgb24("foo", {r: 255, g: 0, b: 255}); - * @param str text color to apply 24bit rgb to - * @param color code - */ -export function bgRgb24(str: string, color: number | Rgb): string { - if (typeof color === "number") { - return run( - str, - code( - [48, 2, (color >> 16) & 0xff, (color >> 8) & 0xff, color & 0xff], - 49, - ), - ); - } - return run( - str, - code( - [ - 48, - 2, - clampAndTruncate(color.r), - clampAndTruncate(color.g), - clampAndTruncate(color.b), - ], - 49, - ), - ); -} - -// https://github.com/chalk/ansi-regex/blob/2b56fb0c7a07108e5b54241e8faec160d393aedb/index.js -const ANSI_PATTERN = new RegExp( - [ - "[\\u001B\\u009B][[\\]()#;?]*(?:(?:(?:[a-zA-Z\\d]*(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]*)*)?\\u0007)", - "(?:(?:\\d{1,4}(?:;\\d{0,4})*)?[\\dA-PR-TZcf-ntqry=><~]))", - ].join("|"), - "g", -); - -/** - * Remove ANSI escape codes from the string. - * @param string to remove ANSI escape codes from - */ -export function stripColor(string: string): string { - return string.replace(ANSI_PATTERN, ""); -} diff --git "a/.\\.cache/deps/https/deno.land/c3031fe6d1ec46c7ee6519cd64b11875eca3b83ce3ceb1323a43a0810846f180.metadata.json" "b/.\\.cache/deps/https/deno.land/c3031fe6d1ec46c7ee6519cd64b11875eca3b83ce3ceb1323a43a0810846f180.metadata.json" deleted file mode 100644 index 788a240..0000000 --- "a/.\\.cache/deps/https/deno.land/c3031fe6d1ec46c7ee6519cd64b11875eca3b83ce3ceb1323a43a0810846f180.metadata.json" +++ /dev/null @@ -1,26 +0,0 @@ -{ - "headers": { - "via": "1.1 16074517396ff3ce754e4ac422c346c8.cloudfront.net (CloudFront)", - "x-amz-replication-status": "FAILED", - "accept-ranges": "bytes", - "content-length": "11534", - "server": "deno/asia-southeast1-a", - "x-cache": "Miss from cloudfront", - "last-modified": "Tue, 09 Mar 2021 20:51:36 GMT", - "access-control-allow-origin": "*", - "x-amz-cf-pop": "SIN52-P1", - "cache-control": "public, max-age=31536000, immutable", - "content-type": "application/typescript; charset=utf-8", - "x-amz-cf-id": "sUT0Vbt2wx6_55PuRCWVAU_lMzpJKsER22pedMtdQvWv3inTn3sZBg==", - "etag": "\"2f4b78d714903ed31adbf934e39dba7d\"", - "date": "Sat, 22 Oct 2022 10:22:52 GMT", - "content-security-policy": "default-src 'none'; style-src 'unsafe-inline'; sandbox", - "x-amz-version-id": "C8dK133OTLoAhq8XAmqc66CkiXwmD2Wa", - "vary": "Accept-Encoding, Origin" - }, - "url": "https://deno.land/std@0.90.0/fmt/colors.ts", - "now": { - "secs_since_epoch": 1666434171, - "nanos_since_epoch": 517815000 - } -} \ No newline at end of file diff --git "a/.\\.cache/gen/file/Users/yashura/Developer/VSCodeProjects/Hackathon/Deeds/tests/deed_test.ts.js" "b/.\\.cache/gen/file/Users/yashura/Developer/VSCodeProjects/Hackathon/Deeds/tests/deed_test.ts.js" deleted file mode 100644 index abb6e4e..0000000 --- "a/.\\.cache/gen/file/Users/yashura/Developer/VSCodeProjects/Hackathon/Deeds/tests/deed_test.ts.js" +++ /dev/null @@ -1,25 +0,0 @@ -import { Clarinet } from "https://deno.land/x/clarinet@v1.0.2/index.ts"; -import { assertEquals } from "https://deno.land/std@0.90.0/testing/asserts.ts"; -// Clarinet Default Test -Clarinet.test({ - name: "Ensure that <...>", - async fn (chain, accounts) { - let block = chain.mineBlock([]); - assertEquals(block.receipts.length, 0); - assertEquals(block.height, 2); - block = chain.mineBlock([]); - assertEquals(block.receipts.length, 0); - assertEquals(block.height, 3); - } -}); -//* Stats to Run the test -const contractname = "deed"; -const defaultStxVaultAmount = 5000; -const defaultMembers = [ - "deployer", - "wallet_1", - "wallet_2", - "wallet_3", - "wallet_4", -]; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbGU6Ly8vVXNlcnMveWFzaHVyYS9EZXZlbG9wZXIvVlNDb2RlUHJvamVjdHMvSGFja2F0aG9uL0RlZWRzL3Rlc3RzL2RlZWRfdGVzdC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDbGFyaW5ldCxcbiAgVHgsXG4gIENoYWluLFxuICBBY2NvdW50LFxuICB0eXBlcyxcbn0gZnJvbSBcImh0dHBzOi8vZGVuby5sYW5kL3gvY2xhcmluZXRAdjEuMC4yL2luZGV4LnRzXCI7XG5pbXBvcnQgeyBhc3NlcnRFcXVhbHMgfSBmcm9tIFwiaHR0cHM6Ly9kZW5vLmxhbmQvc3RkQDAuOTAuMC90ZXN0aW5nL2Fzc2VydHMudHNcIjtcblxuLy8gQ2xhcmluZXQgRGVmYXVsdCBUZXN0XG5DbGFyaW5ldC50ZXN0KHtcbiAgbmFtZTogXCJFbnN1cmUgdGhhdCA8Li4uPlwiLFxuICBhc3luYyBmbihjaGFpbjogQ2hhaW4sIGFjY291bnRzOiBNYXA8c3RyaW5nLCBBY2NvdW50Pikge1xuICAgIGxldCBibG9jayA9IGNoYWluLm1pbmVCbG9jayhbXG4gICAgICAvKlxuICAgICAgICogQWRkIHRyYW5zYWN0aW9ucyB3aXRoOlxuICAgICAgICogVHguY29udHJhY3RDYWxsKC4uLilcbiAgICAgICAqL1xuICAgIF0pO1xuICAgIGFzc2VydEVxdWFscyhibG9jay5yZWNlaXB0cy5sZW5ndGgsIDApO1xuICAgIGFzc2VydEVxdWFscyhibG9jay5oZWlnaHQsIDIpO1xuXG4gICAgYmxvY2sgPSBjaGFpbi5taW5lQmxvY2soW1xuICAgICAgLypcbiAgICAgICAqIEFkZCB0cmFuc2FjdGlvbnMgd2l0aDpcbiAgICAgICAqIFR4LmNvbnRyYWN0Q2FsbCguLi4pXG4gICAgICAgKi9cbiAgICBdKTtcbiAgICBhc3NlcnRFcXVhbHMoYmxvY2sucmVjZWlwdHMubGVuZ3RoLCAwKTtcbiAgICBhc3NlcnRFcXVhbHMoYmxvY2suaGVpZ2h0LCAzKTtcbiAgfSxcbn0pO1xuXG4vLyogU3RhdHMgdG8gUnVuIHRoZSB0ZXN0XG5jb25zdCBjb250cmFjdG5hbWUgPSBcImRlZWRcIjtcblxuY29uc3QgZGVmYXVsdFN0eFZhdWx0QW1vdW50ID0gNTAwMDtcbmNvbnN0IGRlZmF1bHRNZW1iZXJzID0gW1xuICBcImRlcGxveWVyXCIsXG4gIFwid2FsbGV0XzFcIixcbiAgXCJ3YWxsZXRfMlwiLFxuICBcIndhbGxldF8zXCIsXG4gIFwid2FsbGV0XzRcIixcbl07XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsU0FDRSxRQUFRLFFBS0gsOENBQThDLENBQUM7QUFDdEQsU0FBUyxZQUFZLFFBQVEsaURBQWlELENBQUM7QUFFL0Usd0JBQXdCO0FBQ3hCLFFBQVEsQ0FBQyxJQUFJLENBQUM7SUFDWixJQUFJLEVBQUUsbUJBQW1CO0lBQ3pCLE1BQU0sRUFBRSxFQUFDLEtBQVksRUFBRSxRQUE4QixFQUFFO1FBQ3JELElBQUksS0FBSyxHQUFHLEtBQUssQ0FBQyxTQUFTLENBQUMsRUFLM0IsQ0FBQyxBQUFDO1FBQ0gsWUFBWSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3ZDLFlBQVksQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBRTlCLEtBQUssR0FBRyxLQUFLLENBQUMsU0FBUyxDQUFDLEVBS3ZCLENBQUMsQ0FBQztRQUNILFlBQVksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUMsQ0FBQztRQUN2QyxZQUFZLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUMsQ0FBQztLQUMvQjtDQUNGLENBQUMsQ0FBQztBQUVILHlCQUF5QjtBQUN6QixNQUFNLFlBQVksR0FBRyxNQUFNLEFBQUM7QUFFNUIsTUFBTSxxQkFBcUIsR0FBRyxJQUFJLEFBQUM7QUFDbkMsTUFBTSxjQUFjLEdBQUc7SUFDckIsVUFBVTtJQUNWLFVBQVU7SUFDVixVQUFVO0lBQ1YsVUFBVTtJQUNWLFVBQVU7Q0FDWCxBQUFDIn0= \ No newline at end of file diff --git "a/.\\.cache/gen/file/Users/yashura/Developer/VSCodeProjects/Hackathon/Deeds/tests/deed_test.ts.meta" "b/.\\.cache/gen/file/Users/yashura/Developer/VSCodeProjects/Hackathon/Deeds/tests/deed_test.ts.meta" deleted file mode 100644 index 0fa16a9..0000000 --- "a/.\\.cache/gen/file/Users/yashura/Developer/VSCodeProjects/Hackathon/Deeds/tests/deed_test.ts.meta" +++ /dev/null @@ -1 +0,0 @@ -{"source_hash":"8357632346833155902","emit_hash":"7647498746124307573"} \ No newline at end of file diff --git "a/.\\.cache/gen/https/deno.land/688e058fb547030f059b02f08b6bc2f36f15d56e6edb3bce6b48fdf563fb7ae9.js" "b/.\\.cache/gen/https/deno.land/688e058fb547030f059b02f08b6bc2f36f15d56e6edb3bce6b48fdf563fb7ae9.js" deleted file mode 100644 index b1b431e..0000000 --- "a/.\\.cache/gen/https/deno.land/688e058fb547030f059b02f08b6bc2f36f15d56e6edb3bce6b48fdf563fb7ae9.js" +++ /dev/null @@ -1,385 +0,0 @@ -// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. -// This module is browser compatible. Do not rely on good formatting of values -// for AssertionError messages in browsers. -import { bold, gray, green, red, stripColor, white } from "../fmt/colors.ts"; -import { diff, DiffType } from "./_diff.ts"; -const CAN_NOT_DISPLAY = "[Cannot display]"; -export class AssertionError extends Error { - constructor(message){ - super(message); - this.name = "AssertionError"; - } -} -/** - * Converts the input into a string. Objects, Sets and Maps are sorted so as to - * make tests less flaky - * @param v Value to be formatted - */ export function _format(v) { - return globalThis.Deno ? Deno.inspect(v, { - depth: Infinity, - sorted: true, - trailingComma: true, - compact: false, - iterableLimit: Infinity - }) : `"${String(v).replace(/(?=["\\])/g, "\\")}"`; -} -/** - * Colors the output of assertion diffs - * @param diffType Difference type, either added or removed - */ function createColor(diffType) { - switch(diffType){ - case DiffType.added: - return (s)=>green(bold(s)); - case DiffType.removed: - return (s)=>red(bold(s)); - default: - return white; - } -} -/** - * Prefixes `+` or `-` in diff output - * @param diffType Difference type, either added or removed - */ function createSign(diffType) { - switch(diffType){ - case DiffType.added: - return "+ "; - case DiffType.removed: - return "- "; - default: - return " "; - } -} -function buildMessage(diffResult) { - const messages = []; - messages.push(""); - messages.push(""); - messages.push(` ${gray(bold("[Diff]"))} ${red(bold("Actual"))} / ${green(bold("Expected"))}`); - messages.push(""); - messages.push(""); - diffResult.forEach((result)=>{ - const c = createColor(result.type); - messages.push(c(`${createSign(result.type)}${result.value}`)); - }); - messages.push(""); - return messages; -} -function isKeyedCollection(x) { - return [ - Symbol.iterator, - "size" - ].every((k)=>k in x); -} -/** - * Deep equality comparison used in assertions - * @param c actual value - * @param d expected value - */ export function equal(c, d) { - const seen = new Map(); - return function compare(a, b) { - // Have to render RegExp & Date for string comparison - // unless it's mistreated as object - if (a && b && (a instanceof RegExp && b instanceof RegExp || a instanceof URL && b instanceof URL)) { - return String(a) === String(b); - } - if (a instanceof Date && b instanceof Date) { - const aTime = a.getTime(); - const bTime = b.getTime(); - // Check for NaN equality manually since NaN is not - // equal to itself. - if (Number.isNaN(aTime) && Number.isNaN(bTime)) { - return true; - } - return a.getTime() === b.getTime(); - } - if (Object.is(a, b)) { - return true; - } - if (a && typeof a === "object" && b && typeof b === "object") { - if (seen.get(a) === b) { - return true; - } - if (Object.keys(a || {}).length !== Object.keys(b || {}).length) { - return false; - } - if (isKeyedCollection(a) && isKeyedCollection(b)) { - if (a.size !== b.size) { - return false; - } - let unmatchedEntries = a.size; - for (const [aKey, aValue] of a.entries()){ - for (const [bKey, bValue] of b.entries()){ - /* Given that Map keys can be references, we need - * to ensure that they are also deeply equal */ if (aKey === aValue && bKey === bValue && compare(aKey, bKey) || compare(aKey, bKey) && compare(aValue, bValue)) { - unmatchedEntries--; - } - } - } - return unmatchedEntries === 0; - } - const merged = { - ...a, - ...b - }; - for (const key of [ - ...Object.getOwnPropertyNames(merged), - ...Object.getOwnPropertySymbols(merged), - ]){ - if (!compare(a && a[key], b && b[key])) { - return false; - } - } - seen.set(a, b); - return true; - } - return false; - }(c, d); -} -/** Make an assertion, error will be thrown if `expr` does not have truthy value. */ export function assert(expr, msg = "") { - if (!expr) { - throw new AssertionError(msg); - } -} -export function assertEquals(actual, expected, msg) { - if (equal(actual, expected)) { - return; - } - let message = ""; - const actualString = _format(actual); - const expectedString = _format(expected); - try { - const diffResult = diff(actualString.split("\n"), expectedString.split("\n")); - const diffMsg = buildMessage(diffResult).join("\n"); - message = `Values are not equal:\n${diffMsg}`; - } catch { - message = `\n${red(CAN_NOT_DISPLAY)} + \n\n`; - } - if (msg) { - message = msg; - } - throw new AssertionError(message); -} -export function assertNotEquals(actual, expected, msg) { - if (!equal(actual, expected)) { - return; - } - let actualString; - let expectedString; - try { - actualString = String(actual); - } catch { - actualString = "[Cannot display]"; - } - try { - expectedString = String(expected); - } catch { - expectedString = "[Cannot display]"; - } - if (!msg) { - msg = `actual: ${actualString} expected: ${expectedString}`; - } - throw new AssertionError(msg); -} -export function assertStrictEquals(actual, expected, msg) { - if (actual === expected) { - return; - } - let message; - if (msg) { - message = msg; - } else { - const actualString = _format(actual); - const expectedString = _format(expected); - if (actualString === expectedString) { - const withOffset = actualString.split("\n").map((l)=>` ${l}`).join("\n"); - message = `Values have the same structure but are not reference-equal:\n\n${red(withOffset)}\n`; - } else { - try { - const diffResult = diff(actualString.split("\n"), expectedString.split("\n")); - const diffMsg = buildMessage(diffResult).join("\n"); - message = `Values are not strictly equal:\n${diffMsg}`; - } catch { - message = `\n${red(CAN_NOT_DISPLAY)} + \n\n`; - } - } - } - throw new AssertionError(message); -} -export function assertNotStrictEquals(actual, expected, msg) { - if (actual !== expected) { - return; - } - throw new AssertionError(msg ?? `Expected "actual" to be strictly unequal to: ${_format(actual)}\n`); -} -/** - * Make an assertion that actual is not null or undefined. If not - * then thrown. - */ export function assertExists(actual, msg) { - if (actual === undefined || actual === null) { - if (!msg) { - msg = `actual: "${actual}" expected to match anything but null or undefined`; - } - throw new AssertionError(msg); - } -} -/** - * Make an assertion that actual includes expected. If not - * then thrown. - */ export function assertStringIncludes(actual, expected, msg) { - if (!actual.includes(expected)) { - if (!msg) { - msg = `actual: "${actual}" expected to contain: "${expected}"`; - } - throw new AssertionError(msg); - } -} -export function assertArrayIncludes(actual, expected, msg) { - const missing = []; - for(let i = 0; i < expected.length; i++){ - let found = false; - for(let j = 0; j < actual.length; j++){ - if (equal(expected[i], actual[j])) { - found = true; - break; - } - } - if (!found) { - missing.push(expected[i]); - } - } - if (missing.length === 0) { - return; - } - if (!msg) { - msg = `actual: "${_format(actual)}" expected to include: "${_format(expected)}"\nmissing: ${_format(missing)}`; - } - throw new AssertionError(msg); -} -/** - * Make an assertion that `actual` match RegExp `expected`. If not - * then thrown - */ export function assertMatch(actual, expected, msg) { - if (!expected.test(actual)) { - if (!msg) { - msg = `actual: "${actual}" expected to match: "${expected}"`; - } - throw new AssertionError(msg); - } -} -/** - * Make an assertion that `actual` not match RegExp `expected`. If match - * then thrown - */ export function assertNotMatch(actual, expected, msg) { - if (expected.test(actual)) { - if (!msg) { - msg = `actual: "${actual}" expected to not match: "${expected}"`; - } - throw new AssertionError(msg); - } -} -/** - * Make an assertion that `actual` object is a subset of `expected` object, deeply. - * If not, then throw. - */ export function assertObjectMatch(actual, expected) { - const seen = new WeakMap(); - return assertEquals(function filter(a, b) { - // Prevent infinite loop with circular references with same filter - if (seen.has(a) && seen.get(a) === b) { - return a; - } - seen.set(a, b); - // Filter keys and symbols which are present in both actual and expected - const filtered = {}; - const entries = [ - ...Object.getOwnPropertyNames(a), - ...Object.getOwnPropertySymbols(a), - ].filter((key)=>key in b).map((key)=>[ - key, - a[key] - ]); - // Build filtered object and filter recursively on nested objects references - for (const [key, value] of entries){ - if (typeof value === "object") { - const subset = b[key]; - if (typeof subset === "object" && subset) { - filtered[key] = filter(value, subset); - continue; - } - } - filtered[key] = value; - } - return filtered; - }(actual, expected), expected); -} -/** - * Forcefully throws a failed assertion - */ export function fail(msg) { - // eslint-disable-next-line @typescript-eslint/no-use-before-define - assert(false, `Failed assertion${msg ? `: ${msg}` : "."}`); -} -/** - * Executes a function, expecting it to throw. If it does not, then it - * throws. An error class and a string that should be included in the - * error message can also be asserted. - */ export function assertThrows(fn, ErrorClass, msgIncludes = "", msg) { - let doesThrow = false; - let error = null; - try { - fn(); - } catch (e) { - if (e instanceof Error === false) { - throw new AssertionError("A non-Error object was thrown."); - } - if (ErrorClass && !(e instanceof ErrorClass)) { - msg = `Expected error to be instance of "${ErrorClass.name}", but was "${e.constructor.name}"${msg ? `: ${msg}` : "."}`; - throw new AssertionError(msg); - } - if (msgIncludes && !stripColor(e.message).includes(stripColor(msgIncludes))) { - msg = `Expected error message to include "${msgIncludes}", but got "${e.message}"${msg ? `: ${msg}` : "."}`; - throw new AssertionError(msg); - } - doesThrow = true; - error = e; - } - if (!doesThrow) { - msg = `Expected function to throw${msg ? `: ${msg}` : "."}`; - throw new AssertionError(msg); - } - return error; -} -/** - * Executes a function which returns a promise, expecting it to throw or reject. - * If it does not, then it throws. An error class and a string that should be - * included in the error message can also be asserted. - */ export async function assertThrowsAsync(fn, ErrorClass, msgIncludes = "", msg) { - let doesThrow = false; - let error = null; - try { - await fn(); - } catch (e) { - if (e instanceof Error === false) { - throw new AssertionError("A non-Error object was thrown or rejected."); - } - if (ErrorClass && !(e instanceof ErrorClass)) { - msg = `Expected error to be instance of "${ErrorClass.name}", but got "${e.name}"${msg ? `: ${msg}` : "."}`; - throw new AssertionError(msg); - } - if (msgIncludes && !stripColor(e.message).includes(stripColor(msgIncludes))) { - msg = `Expected error message to include "${msgIncludes}", but got "${e.message}"${msg ? `: ${msg}` : "."}`; - throw new AssertionError(msg); - } - doesThrow = true; - error = e; - } - if (!doesThrow) { - msg = `Expected function to throw${msg ? `: ${msg}` : "."}`; - throw new AssertionError(msg); - } - return error; -} -/** Use this to stub out methods that will throw when invoked. */ export function unimplemented(msg) { - throw new AssertionError(msg || "unimplemented"); -} -/** Use this to assert unreachable code. */ export function unreachable() { - throw new AssertionError("unreachable"); -} -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["https://deno.land/std@0.90.0/testing/asserts.ts"],"sourcesContent":["// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.\n// This module is browser compatible. Do not rely on good formatting of values\n// for AssertionError messages in browsers.\n\nimport { bold, gray, green, red, stripColor, white } from \"../fmt/colors.ts\";\nimport { diff, DiffResult, DiffType } from \"./_diff.ts\";\n\nconst CAN_NOT_DISPLAY = \"[Cannot display]\";\n\ninterface Constructor {\n  // deno-lint-ignore no-explicit-any\n  new (...args: any[]): any;\n}\n\nexport class AssertionError extends Error {\n  constructor(message: string) {\n    super(message);\n    this.name = \"AssertionError\";\n  }\n}\n\n/**\n * Converts the input into a string. Objects, Sets and Maps are sorted so as to\n * make tests less flaky\n * @param v Value to be formatted\n */\nexport function _format(v: unknown): string {\n  return globalThis.Deno\n    ? Deno.inspect(v, {\n      depth: Infinity,\n      sorted: true,\n      trailingComma: true,\n      compact: false,\n      iterableLimit: Infinity,\n    })\n    : `\"${String(v).replace(/(?=[\"\\\\])/g, \"\\\\\")}\"`;\n}\n\n/**\n * Colors the output of assertion diffs\n * @param diffType Difference type, either added or removed\n */\nfunction createColor(diffType: DiffType): (s: string) => string {\n  switch (diffType) {\n    case DiffType.added:\n      return (s: string): string => green(bold(s));\n    case DiffType.removed:\n      return (s: string): string => red(bold(s));\n    default:\n      return white;\n  }\n}\n\n/**\n * Prefixes `+` or `-` in diff output\n * @param diffType Difference type, either added or removed\n */\nfunction createSign(diffType: DiffType): string {\n  switch (diffType) {\n    case DiffType.added:\n      return \"+   \";\n    case DiffType.removed:\n      return \"-   \";\n    default:\n      return \"    \";\n  }\n}\n\nfunction buildMessage(diffResult: ReadonlyArray<DiffResult<string>>): string[] {\n  const messages: string[] = [];\n  messages.push(\"\");\n  messages.push(\"\");\n  messages.push(\n    `    ${gray(bold(\"[Diff]\"))} ${red(bold(\"Actual\"))} / ${\n      green(bold(\"Expected\"))\n    }`,\n  );\n  messages.push(\"\");\n  messages.push(\"\");\n  diffResult.forEach((result: DiffResult<string>): void => {\n    const c = createColor(result.type);\n    messages.push(c(`${createSign(result.type)}${result.value}`));\n  });\n  messages.push(\"\");\n\n  return messages;\n}\n\nfunction isKeyedCollection(x: unknown): x is Set<unknown> {\n  return [Symbol.iterator, \"size\"].every((k) => k in (x as Set<unknown>));\n}\n\n/**\n * Deep equality comparison used in assertions\n * @param c actual value\n * @param d expected value\n */\nexport function equal(c: unknown, d: unknown): boolean {\n  const seen = new Map();\n  return (function compare(a: unknown, b: unknown): boolean {\n    // Have to render RegExp & Date for string comparison\n    // unless it's mistreated as object\n    if (\n      a &&\n      b &&\n      ((a instanceof RegExp && b instanceof RegExp) ||\n        (a instanceof URL && b instanceof URL))\n    ) {\n      return String(a) === String(b);\n    }\n    if (a instanceof Date && b instanceof Date) {\n      const aTime = a.getTime();\n      const bTime = b.getTime();\n      // Check for NaN equality manually since NaN is not\n      // equal to itself.\n      if (Number.isNaN(aTime) && Number.isNaN(bTime)) {\n        return true;\n      }\n      return a.getTime() === b.getTime();\n    }\n    if (Object.is(a, b)) {\n      return true;\n    }\n    if (a && typeof a === \"object\" && b && typeof b === \"object\") {\n      if (seen.get(a) === b) {\n        return true;\n      }\n      if (Object.keys(a || {}).length !== Object.keys(b || {}).length) {\n        return false;\n      }\n      if (isKeyedCollection(a) && isKeyedCollection(b)) {\n        if (a.size !== b.size) {\n          return false;\n        }\n\n        let unmatchedEntries = a.size;\n\n        for (const [aKey, aValue] of a.entries()) {\n          for (const [bKey, bValue] of b.entries()) {\n            /* Given that Map keys can be references, we need\n             * to ensure that they are also deeply equal */\n            if (\n              (aKey === aValue && bKey === bValue && compare(aKey, bKey)) ||\n              (compare(aKey, bKey) && compare(aValue, bValue))\n            ) {\n              unmatchedEntries--;\n            }\n          }\n        }\n\n        return unmatchedEntries === 0;\n      }\n      const merged = { ...a, ...b };\n      for (\n        const key of [\n          ...Object.getOwnPropertyNames(merged),\n          ...Object.getOwnPropertySymbols(merged),\n        ]\n      ) {\n        type Key = keyof typeof merged;\n        if (!compare(a && a[key as Key], b && b[key as Key])) {\n          return false;\n        }\n      }\n      seen.set(a, b);\n      return true;\n    }\n    return false;\n  })(c, d);\n}\n\n/** Make an assertion, error will be thrown if `expr` does not have truthy value. */\nexport function assert(expr: unknown, msg = \"\"): asserts expr {\n  if (!expr) {\n    throw new AssertionError(msg);\n  }\n}\n\n/**\n * Make an assertion that `actual` and `expected` are equal, deeply. If not\n * deeply equal, then throw.\n *\n * Type parameter can be specified to ensure values under comparison have the same type.\n * For example:\n *```ts\n *assertEquals<number>(1, 2)\n *```\n */\nexport function assertEquals(\n  actual: unknown,\n  expected: unknown,\n  msg?: string,\n): void;\nexport function assertEquals<T>(actual: T, expected: T, msg?: string): void;\nexport function assertEquals(\n  actual: unknown,\n  expected: unknown,\n  msg?: string,\n): void {\n  if (equal(actual, expected)) {\n    return;\n  }\n  let message = \"\";\n  const actualString = _format(actual);\n  const expectedString = _format(expected);\n  try {\n    const diffResult = diff(\n      actualString.split(\"\\n\"),\n      expectedString.split(\"\\n\"),\n    );\n    const diffMsg = buildMessage(diffResult).join(\"\\n\");\n    message = `Values are not equal:\\n${diffMsg}`;\n  } catch {\n    message = `\\n${red(CAN_NOT_DISPLAY)} + \\n\\n`;\n  }\n  if (msg) {\n    message = msg;\n  }\n  throw new AssertionError(message);\n}\n\n/**\n * Make an assertion that `actual` and `expected` are not equal, deeply.\n * If not then throw.\n *\n * Type parameter can be specified to ensure values under comparison have the same type.\n * For example:\n *```ts\n *assertNotEquals<number>(1, 2)\n *```\n */\nexport function assertNotEquals(\n  actual: unknown,\n  expected: unknown,\n  msg?: string,\n): void;\nexport function assertNotEquals<T>(actual: T, expected: T, msg?: string): void;\nexport function assertNotEquals(\n  actual: unknown,\n  expected: unknown,\n  msg?: string,\n): void {\n  if (!equal(actual, expected)) {\n    return;\n  }\n  let actualString: string;\n  let expectedString: string;\n  try {\n    actualString = String(actual);\n  } catch {\n    actualString = \"[Cannot display]\";\n  }\n  try {\n    expectedString = String(expected);\n  } catch {\n    expectedString = \"[Cannot display]\";\n  }\n  if (!msg) {\n    msg = `actual: ${actualString} expected: ${expectedString}`;\n  }\n  throw new AssertionError(msg);\n}\n\n/**\n * Make an assertion that `actual` and `expected` are strictly equal.  If\n * not then throw.\n * ```ts\n * assertStrictEquals(1, 2)\n * ```\n */\nexport function assertStrictEquals(\n  actual: unknown,\n  expected: unknown,\n  msg?: string,\n): void;\nexport function assertStrictEquals<T>(\n  actual: T,\n  expected: T,\n  msg?: string,\n): void;\nexport function assertStrictEquals(\n  actual: unknown,\n  expected: unknown,\n  msg?: string,\n): void {\n  if (actual === expected) {\n    return;\n  }\n\n  let message: string;\n\n  if (msg) {\n    message = msg;\n  } else {\n    const actualString = _format(actual);\n    const expectedString = _format(expected);\n\n    if (actualString === expectedString) {\n      const withOffset = actualString\n        .split(\"\\n\")\n        .map((l) => `    ${l}`)\n        .join(\"\\n\");\n      message =\n        `Values have the same structure but are not reference-equal:\\n\\n${\n          red(withOffset)\n        }\\n`;\n    } else {\n      try {\n        const diffResult = diff(\n          actualString.split(\"\\n\"),\n          expectedString.split(\"\\n\"),\n        );\n        const diffMsg = buildMessage(diffResult).join(\"\\n\");\n        message = `Values are not strictly equal:\\n${diffMsg}`;\n      } catch {\n        message = `\\n${red(CAN_NOT_DISPLAY)} + \\n\\n`;\n      }\n    }\n  }\n\n  throw new AssertionError(message);\n}\n\n/**\n * Make an assertion that `actual` and `expected` are not strictly equal.\n * If the values are strictly equal then throw.\n * ```ts\n * assertNotStrictEquals(1, 1)\n * ```\n */\nexport function assertNotStrictEquals(\n  actual: unknown,\n  expected: unknown,\n  msg?: string,\n): void;\nexport function assertNotStrictEquals<T>(\n  actual: T,\n  expected: T,\n  msg?: string,\n): void;\nexport function assertNotStrictEquals(\n  actual: unknown,\n  expected: unknown,\n  msg?: string,\n): void {\n  if (actual !== expected) {\n    return;\n  }\n\n  throw new AssertionError(\n    msg ?? `Expected \"actual\" to be strictly unequal to: ${_format(actual)}\\n`,\n  );\n}\n\n/**\n * Make an assertion that actual is not null or undefined. If not\n * then thrown.\n */\nexport function assertExists(\n  actual: unknown,\n  msg?: string,\n): void {\n  if (actual === undefined || actual === null) {\n    if (!msg) {\n      msg =\n        `actual: \"${actual}\" expected to match anything but null or undefined`;\n    }\n    throw new AssertionError(msg);\n  }\n}\n\n/**\n * Make an assertion that actual includes expected. If not\n * then thrown.\n */\nexport function assertStringIncludes(\n  actual: string,\n  expected: string,\n  msg?: string,\n): void {\n  if (!actual.includes(expected)) {\n    if (!msg) {\n      msg = `actual: \"${actual}\" expected to contain: \"${expected}\"`;\n    }\n    throw new AssertionError(msg);\n  }\n}\n\n/**\n * Make an assertion that `actual` includes the `expected` values.\n * If not then an error will be thrown.\n *\n * Type parameter can be specified to ensure values under comparison have the same type.\n * For example:\n *```ts\n *assertArrayIncludes<number>([1, 2], [2])\n *```\n */\nexport function assertArrayIncludes(\n  actual: ArrayLike<unknown>,\n  expected: ArrayLike<unknown>,\n  msg?: string,\n): void;\nexport function assertArrayIncludes<T>(\n  actual: ArrayLike<T>,\n  expected: ArrayLike<T>,\n  msg?: string,\n): void;\nexport function assertArrayIncludes(\n  actual: ArrayLike<unknown>,\n  expected: ArrayLike<unknown>,\n  msg?: string,\n): void {\n  const missing: unknown[] = [];\n  for (let i = 0; i < expected.length; i++) {\n    let found = false;\n    for (let j = 0; j < actual.length; j++) {\n      if (equal(expected[i], actual[j])) {\n        found = true;\n        break;\n      }\n    }\n    if (!found) {\n      missing.push(expected[i]);\n    }\n  }\n  if (missing.length === 0) {\n    return;\n  }\n  if (!msg) {\n    msg = `actual: \"${_format(actual)}\" expected to include: \"${\n      _format(expected)\n    }\"\\nmissing: ${_format(missing)}`;\n  }\n  throw new AssertionError(msg);\n}\n\n/**\n * Make an assertion that `actual` match RegExp `expected`. If not\n * then thrown\n */\nexport function assertMatch(\n  actual: string,\n  expected: RegExp,\n  msg?: string,\n): void {\n  if (!expected.test(actual)) {\n    if (!msg) {\n      msg = `actual: \"${actual}\" expected to match: \"${expected}\"`;\n    }\n    throw new AssertionError(msg);\n  }\n}\n\n/**\n * Make an assertion that `actual` not match RegExp `expected`. If match\n * then thrown\n */\nexport function assertNotMatch(\n  actual: string,\n  expected: RegExp,\n  msg?: string,\n): void {\n  if (expected.test(actual)) {\n    if (!msg) {\n      msg = `actual: \"${actual}\" expected to not match: \"${expected}\"`;\n    }\n    throw new AssertionError(msg);\n  }\n}\n\n/**\n * Make an assertion that `actual` object is a subset of `expected` object, deeply.\n * If not, then throw.\n */\nexport function assertObjectMatch(\n  actual: Record<PropertyKey, unknown>,\n  expected: Record<PropertyKey, unknown>,\n): void {\n  type loose = Record<PropertyKey, unknown>;\n  const seen = new WeakMap();\n  return assertEquals(\n    (function filter(a: loose, b: loose): loose {\n      // Prevent infinite loop with circular references with same filter\n      if ((seen.has(a)) && (seen.get(a) === b)) {\n        return a;\n      }\n      seen.set(a, b);\n      // Filter keys and symbols which are present in both actual and expected\n      const filtered = {} as loose;\n      const entries = [\n        ...Object.getOwnPropertyNames(a),\n        ...Object.getOwnPropertySymbols(a),\n      ]\n        .filter((key) => key in b)\n        .map((key) => [key, a[key as string]]) as Array<[string, unknown]>;\n      // Build filtered object and filter recursively on nested objects references\n      for (const [key, value] of entries) {\n        if (typeof value === \"object\") {\n          const subset = (b as loose)[key];\n          if ((typeof subset === \"object\") && (subset)) {\n            filtered[key] = filter(value as loose, subset as loose);\n            continue;\n          }\n        }\n        filtered[key] = value;\n      }\n      return filtered;\n    })(actual, expected),\n    expected,\n  );\n}\n\n/**\n * Forcefully throws a failed assertion\n */\nexport function fail(msg?: string): void {\n  // eslint-disable-next-line @typescript-eslint/no-use-before-define\n  assert(false, `Failed assertion${msg ? `: ${msg}` : \".\"}`);\n}\n\n/**\n * Executes a function, expecting it to throw.  If it does not, then it\n * throws.  An error class and a string that should be included in the\n * error message can also be asserted.\n */\nexport function assertThrows<T = void>(\n  fn: () => T,\n  ErrorClass?: Constructor,\n  msgIncludes = \"\",\n  msg?: string,\n): Error {\n  let doesThrow = false;\n  let error = null;\n  try {\n    fn();\n  } catch (e) {\n    if (e instanceof Error === false) {\n      throw new AssertionError(\"A non-Error object was thrown.\");\n    }\n    if (ErrorClass && !(e instanceof ErrorClass)) {\n      msg =\n        `Expected error to be instance of \"${ErrorClass.name}\", but was \"${e.constructor.name}\"${\n          msg ? `: ${msg}` : \".\"\n        }`;\n      throw new AssertionError(msg);\n    }\n    if (\n      msgIncludes &&\n      !stripColor(e.message).includes(stripColor(msgIncludes))\n    ) {\n      msg =\n        `Expected error message to include \"${msgIncludes}\", but got \"${e.message}\"${\n          msg ? `: ${msg}` : \".\"\n        }`;\n      throw new AssertionError(msg);\n    }\n    doesThrow = true;\n    error = e;\n  }\n  if (!doesThrow) {\n    msg = `Expected function to throw${msg ? `: ${msg}` : \".\"}`;\n    throw new AssertionError(msg);\n  }\n  return error;\n}\n\n/**\n * Executes a function which returns a promise, expecting it to throw or reject.\n * If it does not, then it throws.  An error class and a string that should be\n * included in the error message can also be asserted.\n */\nexport async function assertThrowsAsync<T = void>(\n  fn: () => Promise<T>,\n  ErrorClass?: Constructor,\n  msgIncludes = \"\",\n  msg?: string,\n): Promise<Error> {\n  let doesThrow = false;\n  let error = null;\n  try {\n    await fn();\n  } catch (e) {\n    if (e instanceof Error === false) {\n      throw new AssertionError(\"A non-Error object was thrown or rejected.\");\n    }\n    if (ErrorClass && !(e instanceof ErrorClass)) {\n      msg =\n        `Expected error to be instance of \"${ErrorClass.name}\", but got \"${e.name}\"${\n          msg ? `: ${msg}` : \".\"\n        }`;\n      throw new AssertionError(msg);\n    }\n    if (\n      msgIncludes &&\n      !stripColor(e.message).includes(stripColor(msgIncludes))\n    ) {\n      msg =\n        `Expected error message to include \"${msgIncludes}\", but got \"${e.message}\"${\n          msg ? `: ${msg}` : \".\"\n        }`;\n      throw new AssertionError(msg);\n    }\n    doesThrow = true;\n    error = e;\n  }\n  if (!doesThrow) {\n    msg = `Expected function to throw${msg ? `: ${msg}` : \".\"}`;\n    throw new AssertionError(msg);\n  }\n  return error;\n}\n\n/** Use this to stub out methods that will throw when invoked. */\nexport function unimplemented(msg?: string): never {\n  throw new AssertionError(msg || \"unimplemented\");\n}\n\n/** Use this to assert unreachable code. */\nexport function unreachable(): never {\n  throw new AssertionError(\"unreachable\");\n}\n"],"names":[],"mappings":"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"} \ No newline at end of file diff --git "a/.\\.cache/gen/https/deno.land/688e058fb547030f059b02f08b6bc2f36f15d56e6edb3bce6b48fdf563fb7ae9.meta" "b/.\\.cache/gen/https/deno.land/688e058fb547030f059b02f08b6bc2f36f15d56e6edb3bce6b48fdf563fb7ae9.meta" deleted file mode 100644 index 2a9b655..0000000 --- "a/.\\.cache/gen/https/deno.land/688e058fb547030f059b02f08b6bc2f36f15d56e6edb3bce6b48fdf563fb7ae9.meta" +++ /dev/null @@ -1 +0,0 @@ -{"source_hash":"9406172266376655746","emit_hash":"7495598743142824601"} \ No newline at end of file diff --git "a/.\\.cache/gen/https/deno.land/7c02e05b5297e003cb3d3ca5a0297c761a2f3a683dbb03ff3a1380681fcb8d54.js" "b/.\\.cache/gen/https/deno.land/7c02e05b5297e003cb3d3ca5a0297c761a2f3a683dbb03ff3a1380681fcb8d54.js" deleted file mode 100644 index c9c0a0d..0000000 --- "a/.\\.cache/gen/https/deno.land/7c02e05b5297e003cb3d3ca5a0297c761a2f3a683dbb03ff3a1380681fcb8d54.js" +++ /dev/null @@ -1,622 +0,0 @@ -export class Tx { - type; - sender; - contractCall; - transferStx; - deployContract; - constructor(type, sender){ - this.type = type; - this.sender = sender; - } - static transferSTX(amount, recipient, sender) { - let tx = new Tx(1, sender); - tx.transferStx = { - recipient, - amount - }; - return tx; - } - static contractCall(contract, method, args, sender) { - let tx = new Tx(2, sender); - tx.contractCall = { - contract, - method, - args - }; - return tx; - } - static deployContract(name, code, sender) { - let tx = new Tx(3, sender); - tx.deployContract = { - name, - code - }; - return tx; - } -} -export class Chain { - sessionId; - blockHeight = 1; - constructor(sessionId){ - this.sessionId = sessionId; - } - mineBlock(transactions) { - // @ts-ignore - let result = JSON.parse(Deno.core.opSync("api/v1/mine_block", { - sessionId: this.sessionId, - transactions: transactions - })); - this.blockHeight = result.block_height; - let block = { - height: result.block_height, - receipts: result.receipts - }; - return block; - } - mineEmptyBlock(count) { - let result = JSON.parse(// @ts-ignore - Deno.core.opSync("api/v1/mine_empty_blocks", { - sessionId: this.sessionId, - count: count - })); - this.blockHeight = result.block_height; - let emptyBlock = { - session_id: result.session_id, - block_height: result.block_height - }; - return emptyBlock; - } - mineEmptyBlockUntil(targetBlockHeight) { - let count = targetBlockHeight - this.blockHeight; - if (count < 0) { - throw new Error(`Chain tip cannot be moved from ${this.blockHeight} to ${targetBlockHeight}`); - } - return this.mineEmptyBlock(count); - } - callReadOnlyFn(contract, method, args, sender) { - let result = JSON.parse(// @ts-ignore - Deno.core.opSync("api/v1/call_read_only_fn", { - sessionId: this.sessionId, - contract: contract, - method: method, - args: args, - sender: sender - })); - let readOnlyFn = { - session_id: result.session_id, - result: result.result, - events: result.events - }; - return readOnlyFn; - } - getAssetsMaps() { - let result = JSON.parse(// @ts-ignore - Deno.core.opSync("api/v1/get_assets_maps", { - sessionId: this.sessionId - })); - let assetsMaps = { - session_id: result.session_id, - assets: result.assets - }; - return assetsMaps; - } -} -export class Clarinet { - static test(options) { - // @ts-ignore - Deno.test({ - name: options.name, - only: options.only, - ignore: options.ignore, - async fn () { - let hasPreDeploymentSteps = options.preDeployment !== undefined; - let result = JSON.parse(// @ts-ignore - Deno.core.opSync("api/v1/new_session", { - name: options.name, - loadDeployment: !hasPreDeploymentSteps, - deploymentPath: options.deploymentPath - })); - if (options.preDeployment) { - let chain = new Chain(result["session_id"]); - let accounts = new Map(); - for (let account of result["accounts"]){ - accounts.set(account.name, account); - } - await options.preDeployment(chain, accounts); - result = JSON.parse(// @ts-ignore - Deno.core.opSync("api/v1/load_deployment", { - sessionId: chain.sessionId, - deploymentPath: options.deploymentPath - })); - } - let chain1 = new Chain(result["session_id"]); - let accounts1 = new Map(); - for (let account1 of result["accounts"]){ - accounts1.set(account1.name, account1); - } - let contracts = new Map(); - for (let contract of result["contracts"]){ - contracts.set(contract.contract_id, contract); - } - await options.fn(chain1, accounts1, contracts); - // @ts-ignore - JSON.parse(Deno.core.opSync("api/v1/terminate_session", { - sessionId: chain1.sessionId - })); - } - }); - } - static run(options) { - // @ts-ignore - Deno.test({ - name: "running script", - async fn () { - let result = JSON.parse(// @ts-ignore - Deno.core.opSync("api/v1/new_session", { - name: "running script", - loadDeployment: true, - deploymentPath: undefined - })); - let accounts = new Map(); - for (let account of result["accounts"]){ - accounts.set(account.name, account); - } - let contracts = new Map(); - for (let contract of result["contracts"]){ - contracts.set(contract.contract_id, contract); - } - let stacks_node = { - url: result["stacks_node_url"] - }; - await options.fn(accounts, contracts, stacks_node); - } - }); - } -} -export var types; -(function(types) { - const byteToHex = []; - for(let n = 0; n <= 0xff; ++n){ - const hexOctet = n.toString(16).padStart(2, "0"); - byteToHex.push(hexOctet); - } - function serializeTuple(input) { - let items = []; - for (var [key, value] of Object.entries(input)){ - if (typeof value === "object") { - items.push(`${key}: { ${serializeTuple(value)} }`); - } else if (Array.isArray(value)) { - // todo(ludo): not supported, should panic - } else { - items.push(`${key}: ${value}`); - } - } - return items.join(", "); - } - function isObject(obj) { - return typeof obj === "object" && !Array.isArray(obj); - } - function ok(val) { - return `(ok ${val})`; - } - types.ok = ok; - function err(val) { - return `(err ${val})`; - } - types.err = err; - function some(val) { - return `(some ${val})`; - } - types.some = some; - function none() { - return `none`; - } - types.none = none; - function bool(val) { - return `${val}`; - } - types.bool = bool; - function int(val) { - return `${val}`; - } - types.int = int; - function uint(val) { - return `u${val}`; - } - types.uint = uint; - function ascii(val) { - return JSON.stringify(val); - } - types.ascii = ascii; - function utf8(val) { - return `u${JSON.stringify(val)}`; - } - types.utf8 = utf8; - function buff(val) { - const buff = typeof val == "string" ? new TextEncoder().encode(val) : new Uint8Array(val); - const hexOctets = new Array(buff.length); - for(let i = 0; i < buff.length; ++i){ - hexOctets[i] = byteToHex[buff[i]]; - } - return `0x${hexOctets.join("")}`; - } - types.buff = buff; - function list(val) { - return `(list ${val.join(" ")})`; - } - types.list = list; - function principal(val) { - return `'${val}`; - } - types.principal = principal; - function tuple(val) { - return `{ ${serializeTuple(val)} }`; - } - types.tuple = tuple; -})(types || (types = {})); -function consume(src, expectation, wrapped) { - let dst = (" " + src).slice(1); - let size = expectation.length; - if (!wrapped && src !== expectation) { - throw new Error(`Expected ${green(expectation.toString())}, got ${red(src.toString())}`); - } - if (wrapped) { - size += 2; - } - if (dst.length < size) { - throw new Error(`Expected ${green(expectation.toString())}, got ${red(src.toString())}`); - } - if (wrapped) { - dst = dst.substring(1, dst.length - 1); - } - let res = dst.slice(0, expectation.length); - if (res !== expectation) { - throw new Error(`Expected ${green(expectation.toString())}, got ${red(src.toString())}`); - } - let leftPad = 0; - if (dst.charAt(expectation.length) === " ") { - leftPad = 1; - } - let remainder = dst.substring(expectation.length + leftPad); - return remainder; -} -String.prototype.expectOk = function() { - return consume(this, "ok", true); -}; -String.prototype.expectErr = function() { - return consume(this, "err", true); -}; -String.prototype.expectSome = function() { - return consume(this, "some", true); -}; -String.prototype.expectNone = function() { - return consume(this, "none", false); -}; -String.prototype.expectBool = function(value) { - try { - consume(this, `${value}`, false); - } catch (error) { - throw error; - } - return value; -}; -String.prototype.expectUint = function(value) { - try { - consume(this, `u${value}`, false); - } catch (error) { - throw error; - } - return BigInt(value); -}; -String.prototype.expectInt = function(value) { - try { - consume(this, `${value}`, false); - } catch (error) { - throw error; - } - return BigInt(value); -}; -String.prototype.expectBuff = function(value) { - let buffer = types.buff(value); - if (this !== buffer) { - throw new Error(`Expected ${green(buffer)}, got ${red(this.toString())}`); - } - return value; -}; -String.prototype.expectAscii = function(value) { - try { - consume(this, `"${value}"`, false); - } catch (error) { - throw error; - } - return value; -}; -String.prototype.expectUtf8 = function(value) { - try { - consume(this, `u"${value}"`, false); - } catch (error) { - throw error; - } - return value; -}; -String.prototype.expectPrincipal = function(value) { - try { - consume(this, `${value}`, false); - } catch (error) { - throw error; - } - return value; -}; -String.prototype.expectList = function() { - if (this.charAt(0) !== "[" || this.charAt(this.length - 1) !== "]") { - throw new Error(`Expected ${green("(list ...)")}, got ${red(this.toString())}`); - } - let stack = []; - let elements = []; - let start = 1; - for(var i = 0; i < this.length; i++){ - if (this.charAt(i) === "," && stack.length == 1) { - elements.push(this.substring(start, i)); - start = i + 2; - } - if ([ - "(", - "[", - "{" - ].includes(this.charAt(i))) { - stack.push(this.charAt(i)); - } - if (this.charAt(i) === ")" && stack[stack.length - 1] === "(") { - stack.pop(); - } - if (this.charAt(i) === "}" && stack[stack.length - 1] === "{") { - stack.pop(); - } - if (this.charAt(i) === "]" && stack[stack.length - 1] === "[") { - stack.pop(); - } - } - let remainder = this.substring(start, this.length - 1); - if (remainder.length > 0) { - elements.push(remainder); - } - return elements; -}; -String.prototype.expectTuple = function() { - if (this.charAt(0) !== "{" || this.charAt(this.length - 1) !== "}") { - throw new Error(`Expected ${green("(tuple ...)")}, got ${red(this.toString())}`); - } - let start = 1; - let stack = []; - let elements = []; - for(var i = 0; i < this.length; i++){ - if (this.charAt(i) === "," && stack.length == 1) { - elements.push(this.substring(start, i)); - start = i + 2; - } - if ([ - "(", - "[", - "{" - ].includes(this.charAt(i))) { - stack.push(this.charAt(i)); - } - if (this.charAt(i) === ")" && stack[stack.length - 1] === "(") { - stack.pop(); - } - if (this.charAt(i) === "}" && stack[stack.length - 1] === "{") { - stack.pop(); - } - if (this.charAt(i) === "]" && stack[stack.length - 1] === "[") { - stack.pop(); - } - } - let remainder = this.substring(start, this.length - 1); - if (remainder.length > 0) { - elements.push(remainder); - } - let tuple = {}; - for (let element of elements){ - for(var i = 0; i < element.length; i++){ - if (element.charAt(i) === ":") { - let key = element.substring(0, i); - let value = element.substring(i + 2, element.length); - tuple[key] = value; - break; - } - } - } - return tuple; -}; -Array.prototype.expectSTXTransferEvent = function(amount, sender, recipient) { - for (let event of this){ - try { - let e = {}; - e["amount"] = event.stx_transfer_event.amount.expectInt(amount); - e["sender"] = event.stx_transfer_event.sender.expectPrincipal(sender); - e["recipient"] = event.stx_transfer_event.recipient.expectPrincipal(recipient); - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected STXTransferEvent`); -}; -Array.prototype.expectFungibleTokenTransferEvent = function(amount, sender, recipient, assetId) { - for (let event of this){ - try { - let e = {}; - e["amount"] = event.ft_transfer_event.amount.expectInt(amount); - e["sender"] = event.ft_transfer_event.sender.expectPrincipal(sender); - e["recipient"] = event.ft_transfer_event.recipient.expectPrincipal(recipient); - if (event.ft_transfer_event.asset_identifier.endsWith(assetId)) { - e["assetId"] = event.ft_transfer_event.asset_identifier; - } else { - continue; - } - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected FungibleTokenTransferEvent(${amount}, ${sender}, ${recipient}, ${assetId})\n${JSON.stringify(this)}`); -}; -Array.prototype.expectFungibleTokenMintEvent = function(amount, recipient, assetId) { - for (let event of this){ - try { - let e = {}; - e["amount"] = event.ft_mint_event.amount.expectInt(amount); - e["recipient"] = event.ft_mint_event.recipient.expectPrincipal(recipient); - if (event.ft_mint_event.asset_identifier.endsWith(assetId)) { - e["assetId"] = event.ft_mint_event.asset_identifier; - } else { - continue; - } - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected FungibleTokenMintEvent`); -}; -Array.prototype.expectFungibleTokenBurnEvent = function(amount, sender, assetId) { - for (let event of this){ - try { - let e = {}; - e["amount"] = event.ft_burn_event.amount.expectInt(amount); - e["sender"] = event.ft_burn_event.sender.expectPrincipal(sender); - if (event.ft_burn_event.asset_identifier.endsWith(assetId)) { - e["assetId"] = event.ft_burn_event.asset_identifier; - } else { - continue; - } - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected FungibleTokenBurnEvent`); -}; -Array.prototype.expectPrintEvent = function(contract_identifier, value) { - for (let event of this){ - try { - let e = {}; - e["contract_identifier"] = event.contract_event.contract_identifier.expectPrincipal(contract_identifier); - if (event.contract_event.topic.endsWith("print")) { - e["topic"] = event.contract_event.topic; - } else { - continue; - } - if (event.contract_event.value.endsWith(value)) { - e["value"] = event.contract_event.value; - } else { - continue; - } - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected PrintEvent`); -}; -// Array.prototype.expectEvent = function(sel: (e: Object) => Object) { -// for (let event of this) { -// try { -// sel(event); -// return event as Object; -// } catch (error) { -// continue; -// } -// } -// throw new Error(`Unable to retrieve expected PrintEvent`); -// } -Array.prototype.expectNonFungibleTokenTransferEvent = function(tokenId, sender, recipient, assetAddress, assetId) { - for (let event of this){ - try { - let e = {}; - if (event.nft_transfer_event.value === tokenId) { - e["tokenId"] = event.nft_transfer_event.value; - } else { - continue; - } - e["sender"] = event.nft_transfer_event.sender.expectPrincipal(sender); - e["recipient"] = event.nft_transfer_event.recipient.expectPrincipal(recipient); - if (event.nft_transfer_event.asset_identifier === `${assetAddress}::${assetId}`) { - e["assetId"] = event.nft_transfer_event.asset_identifier; - } else { - continue; - } - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected NonFungibleTokenTransferEvent`); -}; -Array.prototype.expectNonFungibleTokenMintEvent = function(tokenId, recipient, assetAddress, assetId) { - for (let event of this){ - try { - let e = {}; - if (event.nft_mint_event.value === tokenId) { - e["tokenId"] = event.nft_mint_event.value; - } else { - continue; - } - e["recipient"] = event.nft_mint_event.recipient.expectPrincipal(recipient); - if (event.nft_mint_event.asset_identifier === `${assetAddress}::${assetId}`) { - e["assetId"] = event.nft_mint_event.asset_identifier; - } else { - continue; - } - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected NonFungibleTokenMintEvent`); -}; -Array.prototype.expectNonFungibleTokenBurnEvent = function(tokenId, sender, assetAddress, assetId) { - for (let event of this){ - try { - let e = {}; - if (event.nft_burn_event.value === tokenId) { - e["tokenId"] = event.nft_burn_event.value; - } else { - continue; - } - e["sender"] = event.nft_burn_event.sender.expectPrincipal(sender); - if (event.nft_burn_event.asset_identifier === `${assetAddress}::${assetId}`) { - e["assetId"] = event.nft_burn_event.asset_identifier; - } else { - continue; - } - return e; - } catch (error) { - continue; - } - } - throw new Error(`Unable to retrieve expected NonFungibleTokenBurnEvent`); -}; -const noColor = globalThis.Deno?.noColor ?? true; -let enabled = !noColor; -function code(open, close) { - return { - open: `\x1b[${open.join(";")}m`, - close: `\x1b[${close}m`, - regexp: new RegExp(`\\x1b\\[${close}m`, "g") - }; -} -function run(str, code) { - return enabled ? `${code.open}${str.replace(code.regexp, code.open)}${code.close}` : str; -} -export function red(str) { - return run(str, code([ - 31 - ], 39)); -} -export function green(str) { - return run(str, code([ - 32 - ], 39)); -} -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["https://deno.land/x/clarinet@v1.0.2/index.ts"],"sourcesContent":["export class Tx {\n  type: number;\n  sender: string;\n  contractCall?: TxContractCall;\n  transferStx?: TxTransfer;\n  deployContract?: TxDeployContract;\n\n  constructor(type: number, sender: string) {\n    this.type = type;\n    this.sender = sender;\n  }\n\n  static transferSTX(amount: number, recipient: string, sender: string) {\n    let tx = new Tx(1, sender);\n    tx.transferStx = {\n      recipient,\n      amount,\n    };\n    return tx;\n  }\n\n  static contractCall(\n    contract: string,\n    method: string,\n    args: Array<string>,\n    sender: string,\n  ) {\n    let tx = new Tx(2, sender);\n    tx.contractCall = {\n      contract,\n      method,\n      args,\n    };\n    return tx;\n  }\n\n  static deployContract(name: string, code: string, sender: string) {\n    let tx = new Tx(3, sender);\n    tx.deployContract = {\n      name,\n      code,\n    };\n    return tx;\n  }\n}\n\nexport interface TxContractCall {\n  contract: string;\n  method: string;\n  args: Array<string>;\n}\n\nexport interface TxDeployContract {\n  code: string;\n  name: string;\n}\n\nexport interface TxTransfer {\n  amount: number;\n  recipient: string;\n}\n\nexport interface TxReceipt {\n  result: string;\n  events: Array<any>;\n}\n\nexport interface Block {\n  height: number;\n  receipts: Array<TxReceipt>;\n}\n\nexport interface Account {\n  address: string;\n  balance: number;\n  name: string;\n}\n\nexport interface Chain {\n  sessionId: number;\n}\n\nexport interface ReadOnlyFn {\n  session_id: number;\n  result: string;\n  events: Array<any>;\n}\n\nexport interface EmptyBlock {\n  session_id: number;\n  block_height: number;\n}\n\nexport interface AssetsMaps {\n  session_id: number;\n  assets: {\n    [name: string]: {\n      [owner: string]: number;\n    };\n  };\n}\n\nexport class Chain {\n  sessionId: number;\n  blockHeight: number = 1;\n\n  constructor(sessionId: number) {\n    this.sessionId = sessionId;\n  }\n\n  mineBlock(transactions: Array<Tx>): Block {\n    // @ts-ignore\n    let result = JSON.parse(Deno.core.opSync(\"api/v1/mine_block\", {\n      sessionId: this.sessionId,\n      transactions: transactions,\n    }));\n    this.blockHeight = result.block_height;\n    let block: Block = {\n      height: result.block_height,\n      receipts: result.receipts,\n    };\n    return block;\n  }\n\n  mineEmptyBlock(count: number): EmptyBlock {\n    let result = JSON.parse(\n      // @ts-ignore\n      Deno.core.opSync(\"api/v1/mine_empty_blocks\", {\n        sessionId: this.sessionId,\n        count: count,\n      }),\n    );\n    this.blockHeight = result.block_height;\n    let emptyBlock: EmptyBlock = {\n      session_id: result.session_id,\n      block_height: result.block_height,\n    };\n    return emptyBlock;\n  }\n\n  mineEmptyBlockUntil(targetBlockHeight: number): EmptyBlock {\n    let count = targetBlockHeight - this.blockHeight;\n    if (count < 0) {\n      throw new Error(\n        `Chain tip cannot be moved from ${this.blockHeight} to ${targetBlockHeight}`,\n      );\n    }\n    return this.mineEmptyBlock(count);\n  }\n\n  callReadOnlyFn(\n    contract: string,\n    method: string,\n    args: Array<any>,\n    sender: string,\n  ): ReadOnlyFn {\n    let result = JSON.parse(\n      // @ts-ignore\n      Deno.core.opSync(\"api/v1/call_read_only_fn\", {\n        sessionId: this.sessionId,\n        contract: contract,\n        method: method,\n        args: args,\n        sender: sender,\n      }),\n    );\n    let readOnlyFn: ReadOnlyFn = {\n      session_id: result.session_id,\n      result: result.result,\n      events: result.events,\n    };\n    return readOnlyFn;\n  }\n\n  getAssetsMaps(): AssetsMaps {\n    let result = JSON.parse(\n      // @ts-ignore\n      Deno.core.opSync(\"api/v1/get_assets_maps\", {\n        sessionId: this.sessionId,\n      }),\n    );\n    let assetsMaps: AssetsMaps = {\n      session_id: result.session_id,\n      assets: result.assets,\n    };\n    return assetsMaps;\n  }\n}\n\ntype PreDeploymentFunction = (\n  chain: Chain,\n  accounts: Map<string, Account>,\n) => void | Promise<void>;\n\ntype TestFunction = (\n  chain: Chain,\n  accounts: Map<string, Account>,\n  contracts: Map<string, Contract>,\n) => void | Promise<void>;\ntype PreSetupFunction = () => Array<Tx>;\n\ninterface UnitTestOptions {\n  name: string;\n  only?: true;\n  ignore?: true;\n  deploymentPath?: string;\n  preDeployment?: PreDeploymentFunction;\n  fn: TestFunction;\n}\n\nexport interface Contract {\n  contract_id: string;\n  source: string;\n  contract_interface: any;\n}\n\nexport interface StacksNode {\n  url: string;\n}\n\ntype ScriptFunction = (\n  accounts: Map<string, Account>,\n  contracts: Map<string, Contract>,\n  node: StacksNode,\n) => void | Promise<void>;\n\ninterface ScriptOptions {\n  fn: ScriptFunction;\n}\n\nexport class Clarinet {\n  static test(options: UnitTestOptions) {\n    // @ts-ignore\n    Deno.test({\n      name: options.name,\n      only: options.only,\n      ignore: options.ignore,\n      async fn() {\n        let hasPreDeploymentSteps = options.preDeployment !== undefined;\n\n        let result = JSON.parse(\n          // @ts-ignore\n          Deno.core.opSync(\"api/v1/new_session\", {\n            name: options.name,\n            loadDeployment: !hasPreDeploymentSteps,\n            deploymentPath: options.deploymentPath,\n          }),\n        );\n\n        if (options.preDeployment) {\n          let chain = new Chain(result[\"session_id\"]);\n          let accounts: Map<string, Account> = new Map();\n          for (let account of result[\"accounts\"]) {\n            accounts.set(account.name, account);\n          }\n          await options.preDeployment(chain, accounts);\n\n          result = JSON.parse(\n            // @ts-ignore\n            Deno.core.opSync(\"api/v1/load_deployment\", {\n              sessionId: chain.sessionId,\n              deploymentPath: options.deploymentPath,\n            }),\n          );\n        }\n\n        let chain = new Chain(result[\"session_id\"]);\n        let accounts: Map<string, Account> = new Map();\n        for (let account of result[\"accounts\"]) {\n          accounts.set(account.name, account);\n        }\n        let contracts: Map<string, Contract> = new Map();\n        for (let contract of result[\"contracts\"]) {\n          contracts.set(contract.contract_id, contract);\n        }\n        await options.fn(chain, accounts, contracts);\n\n        // @ts-ignore\n        JSON.parse(Deno.core.opSync(\"api/v1/terminate_session\", {\n          sessionId: chain.sessionId,\n        }));\n      },\n    });\n  }\n\n  static run(options: ScriptOptions) {\n    // @ts-ignore\n    Deno.test({\n      name: \"running script\",\n      async fn() {\n        let result = JSON.parse(\n          // @ts-ignore\n          Deno.core.opSync(\"api/v1/new_session\", {\n            name: \"running script\",\n            loadDeployment: true,\n            deploymentPath: undefined,\n          }),\n        );\n        let accounts: Map<string, Account> = new Map();\n        for (let account of result[\"accounts\"]) {\n          accounts.set(account.name, account);\n        }\n        let contracts: Map<string, Contract> = new Map();\n        for (let contract of result[\"contracts\"]) {\n          contracts.set(contract.contract_id, contract);\n        }\n        let stacks_node: StacksNode = {\n          url: result[\"stacks_node_url\"],\n        };\n        await options.fn(accounts, contracts, stacks_node);\n      },\n    });\n  }\n}\n\nexport namespace types {\n  const byteToHex: any = [];\n  for (let n = 0; n <= 0xff; ++n) {\n    const hexOctet = n.toString(16).padStart(2, \"0\");\n    byteToHex.push(hexOctet);\n  }\n\n  function serializeTuple(input: Object) {\n    let items: Array<string> = [];\n    for (var [key, value] of Object.entries(input)) {\n      if (typeof value === \"object\") {\n        items.push(`${key}: { ${serializeTuple(value)} }`);\n      } else if (Array.isArray(value)) {\n        // todo(ludo): not supported, should panic\n      } else {\n        items.push(`${key}: ${value}`);\n      }\n    }\n    return items.join(\", \");\n  }\n\n  function isObject(obj: any) {\n    return typeof obj === \"object\" && !Array.isArray(obj);\n  }\n\n  export function ok(val: string) {\n    return `(ok ${val})`;\n  }\n\n  export function err(val: string) {\n    return `(err ${val})`;\n  }\n\n  export function some(val: string) {\n    return `(some ${val})`;\n  }\n\n  export function none() {\n    return `none`;\n  }\n\n  export function bool(val: boolean) {\n    return `${val}`;\n  }\n\n  export function int(val: number | bigint) {\n    return `${val}`;\n  }\n\n  export function uint(val: number | bigint) {\n    return `u${val}`;\n  }\n\n  export function ascii(val: string) {\n    return JSON.stringify(val);\n  }\n\n  export function utf8(val: string) {\n    return `u${JSON.stringify(val)}`;\n  }\n\n  export function buff(val: ArrayBuffer | string) {\n    const buff = typeof val == \"string\"\n      ? new TextEncoder().encode(val)\n      : new Uint8Array(val);\n\n    const hexOctets = new Array(buff.length);\n\n    for (let i = 0; i < buff.length; ++i) {\n      hexOctets[i] = byteToHex[buff[i]];\n    }\n\n    return `0x${hexOctets.join(\"\")}`;\n  }\n\n  export function list(val: Array<any>) {\n    return `(list ${val.join(\" \")})`;\n  }\n\n  export function principal(val: string) {\n    return `'${val}`;\n  }\n\n  export function tuple(val: Object) {\n    return `{ ${serializeTuple(val)} }`;\n  }\n}\n\ndeclare global {\n  interface String {\n    expectOk(): String;\n    expectErr(): String;\n    expectSome(): String;\n    expectNone(): void;\n    expectBool(value: boolean): boolean;\n    expectUint(value: number | bigint): bigint;\n    expectInt(value: number | bigint): bigint;\n    expectBuff(value: ArrayBuffer): ArrayBuffer;\n    expectAscii(value: String): String;\n    expectUtf8(value: String): String;\n    expectPrincipal(value: String): String;\n    expectList(): Array<String>;\n    expectTuple(): Record<string, string>;\n  }\n\n  interface Array<T> {\n    expectSTXTransferEvent(\n      amount: Number | bigint,\n      sender: String,\n      recipient: String,\n    ): Object;\n    expectFungibleTokenTransferEvent(\n      amount: Number | bigint,\n      sender: String,\n      recipient: String,\n      assetId: String,\n    ): Object;\n    expectFungibleTokenMintEvent(\n      amount: Number | bigint,\n      recipient: String,\n      assetId: String,\n    ): Object;\n    expectFungibleTokenBurnEvent(\n      amount: Number | bigint,\n      sender: String,\n      assetId: String,\n    ): Object;\n    expectPrintEvent(\n      contract_identifier: string,\n      value: string,\n    ): Object;\n    expectNonFungibleTokenTransferEvent(\n      tokenId: String,\n      sender: String,\n      recipient: String,\n      assetAddress: String,\n      assetId: String,\n    ): Object;\n    expectNonFungibleTokenMintEvent(\n      tokenId: String,\n      recipient: String,\n      assetAddress: String,\n      assetId: String,\n    ): Object;\n    expectNonFungibleTokenBurnEvent(\n      tokenId: String,\n      sender: String,\n      assetAddress: String,\n      assetId: String,\n    ): Object;\n    // expectEvent(sel: (e: Object) => Object): Object;\n  }\n}\n\nfunction consume(src: String, expectation: String, wrapped: boolean) {\n  let dst = (\" \" + src).slice(1);\n  let size = expectation.length;\n  if (!wrapped && src !== expectation) {\n    throw new Error(\n      `Expected ${green(expectation.toString())}, got ${red(src.toString())}`,\n    );\n  }\n  if (wrapped) {\n    size += 2;\n  }\n  if (dst.length < size) {\n    throw new Error(\n      `Expected ${green(expectation.toString())}, got ${red(src.toString())}`,\n    );\n  }\n  if (wrapped) {\n    dst = dst.substring(1, dst.length - 1);\n  }\n  let res = dst.slice(0, expectation.length);\n  if (res !== expectation) {\n    throw new Error(\n      `Expected ${green(expectation.toString())}, got ${red(src.toString())}`,\n    );\n  }\n  let leftPad = 0;\n  if (dst.charAt(expectation.length) === \" \") {\n    leftPad = 1;\n  }\n  let remainder = dst.substring(expectation.length + leftPad);\n  return remainder;\n}\n\nString.prototype.expectOk = function () {\n  return consume(this, \"ok\", true);\n};\n\nString.prototype.expectErr = function () {\n  return consume(this, \"err\", true);\n};\n\nString.prototype.expectSome = function () {\n  return consume(this, \"some\", true);\n};\n\nString.prototype.expectNone = function () {\n  return consume(this, \"none\", false);\n};\n\nString.prototype.expectBool = function (value: boolean) {\n  try {\n    consume(this, `${value}`, false);\n  } catch (error) {\n    throw error;\n  }\n  return value;\n};\n\nString.prototype.expectUint = function (value: number | bigint): bigint {\n  try {\n    consume(this, `u${value}`, false);\n  } catch (error) {\n    throw error;\n  }\n  return BigInt(value);\n};\n\nString.prototype.expectInt = function (value: number | bigint): bigint {\n  try {\n    consume(this, `${value}`, false);\n  } catch (error) {\n    throw error;\n  }\n  return BigInt(value);\n};\n\nString.prototype.expectBuff = function (value: ArrayBuffer) {\n  let buffer = types.buff(value);\n  if (this !== buffer) {\n    throw new Error(`Expected ${green(buffer)}, got ${red(this.toString())}`);\n  }\n  return value;\n};\n\nString.prototype.expectAscii = function (value: string) {\n  try {\n    consume(this, `\"${value}\"`, false);\n  } catch (error) {\n    throw error;\n  }\n  return value;\n};\n\nString.prototype.expectUtf8 = function (value: string) {\n  try {\n    consume(this, `u\"${value}\"`, false);\n  } catch (error) {\n    throw error;\n  }\n  return value;\n};\n\nString.prototype.expectPrincipal = function (value: string) {\n  try {\n    consume(this, `${value}`, false);\n  } catch (error) {\n    throw error;\n  }\n  return value;\n};\n\nString.prototype.expectList = function () {\n  if (this.charAt(0) !== \"[\" || this.charAt(this.length - 1) !== \"]\") {\n    throw new Error(\n      `Expected ${green(\"(list ...)\")}, got ${red(this.toString())}`,\n    );\n  }\n\n  let stack = [];\n  let elements = [];\n  let start = 1;\n  for (var i = 0; i < this.length; i++) {\n    if (this.charAt(i) === \",\" && stack.length == 1) {\n      elements.push(this.substring(start, i));\n      start = i + 2;\n    }\n    if ([\"(\", \"[\", \"{\"].includes(this.charAt(i))) {\n      stack.push(this.charAt(i));\n    }\n    if (this.charAt(i) === \")\" && stack[stack.length - 1] === \"(\") {\n      stack.pop();\n    }\n    if (this.charAt(i) === \"}\" && stack[stack.length - 1] === \"{\") {\n      stack.pop();\n    }\n    if (this.charAt(i) === \"]\" && stack[stack.length - 1] === \"[\") {\n      stack.pop();\n    }\n  }\n  let remainder = this.substring(start, this.length - 1);\n  if (remainder.length > 0) {\n    elements.push(remainder);\n  }\n  return elements;\n};\n\nString.prototype.expectTuple = function () {\n  if (this.charAt(0) !== \"{\" || this.charAt(this.length - 1) !== \"}\") {\n    throw new Error(\n      `Expected ${green(\"(tuple ...)\")}, got ${red(this.toString())}`,\n    );\n  }\n\n  let start = 1;\n  let stack = [];\n  let elements = [];\n  for (var i = 0; i < this.length; i++) {\n    if (this.charAt(i) === \",\" && stack.length == 1) {\n      elements.push(this.substring(start, i));\n      start = i + 2;\n    }\n    if ([\"(\", \"[\", \"{\"].includes(this.charAt(i))) {\n      stack.push(this.charAt(i));\n    }\n    if (this.charAt(i) === \")\" && stack[stack.length - 1] === \"(\") {\n      stack.pop();\n    }\n    if (this.charAt(i) === \"}\" && stack[stack.length - 1] === \"{\") {\n      stack.pop();\n    }\n    if (this.charAt(i) === \"]\" && stack[stack.length - 1] === \"[\") {\n      stack.pop();\n    }\n  }\n  let remainder = this.substring(start, this.length - 1);\n  if (remainder.length > 0) {\n    elements.push(remainder);\n  }\n\n  let tuple: Record<string, string> = {};\n  for (let element of elements) {\n    for (var i = 0; i < element.length; i++) {\n      if (element.charAt(i) === \":\") {\n        let key: string = element.substring(0, i);\n        let value: string = element.substring(i + 2, element.length);\n        tuple[key] = value;\n        break;\n      }\n    }\n  }\n\n  return tuple;\n};\n\nArray.prototype.expectSTXTransferEvent = function (\n  amount: Number | bigint,\n  sender: String,\n  recipient: String,\n) {\n  for (let event of this) {\n    try {\n      let e: any = {};\n      e[\"amount\"] = event.stx_transfer_event.amount.expectInt(amount);\n      e[\"sender\"] = event.stx_transfer_event.sender.expectPrincipal(sender);\n      e[\"recipient\"] = event.stx_transfer_event.recipient.expectPrincipal(\n        recipient,\n      );\n      return e;\n    } catch (error) {\n      continue;\n    }\n  }\n  throw new Error(`Unable to retrieve expected STXTransferEvent`);\n};\n\nArray.prototype.expectFungibleTokenTransferEvent = function (\n  amount: Number,\n  sender: String,\n  recipient: String,\n  assetId: String,\n) {\n  for (let event of this) {\n    try {\n      let e: any = {};\n      e[\"amount\"] = event.ft_transfer_event.amount.expectInt(amount);\n      e[\"sender\"] = event.ft_transfer_event.sender.expectPrincipal(sender);\n      e[\"recipient\"] = event.ft_transfer_event.recipient.expectPrincipal(\n        recipient,\n      );\n      if (event.ft_transfer_event.asset_identifier.endsWith(assetId)) {\n        e[\"assetId\"] = event.ft_transfer_event.asset_identifier;\n      } else {\n        continue;\n      }\n      return e;\n    } catch (error) {\n      continue;\n    }\n  }\n  throw new Error(\n    `Unable to retrieve expected FungibleTokenTransferEvent(${amount}, ${sender}, ${recipient}, ${assetId})\\n${\n      JSON.stringify(this)\n    }`,\n  );\n};\n\nArray.prototype.expectFungibleTokenMintEvent = function (\n  amount: Number | bigint,\n  recipient: String,\n  assetId: String,\n) {\n  for (let event of this) {\n    try {\n      let e: any = {};\n      e[\"amount\"] = event.ft_mint_event.amount.expectInt(amount);\n      e[\"recipient\"] = event.ft_mint_event.recipient.expectPrincipal(recipient);\n      if (event.ft_mint_event.asset_identifier.endsWith(assetId)) {\n        e[\"assetId\"] = event.ft_mint_event.asset_identifier;\n      } else {\n        continue;\n      }\n      return e;\n    } catch (error) {\n      continue;\n    }\n  }\n  throw new Error(`Unable to retrieve expected FungibleTokenMintEvent`);\n};\n\nArray.prototype.expectFungibleTokenBurnEvent = function (\n  amount: Number | bigint,\n  sender: String,\n  assetId: String,\n) {\n  for (let event of this) {\n    try {\n      let e: any = {};\n      e[\"amount\"] = event.ft_burn_event.amount.expectInt(amount);\n      e[\"sender\"] = event.ft_burn_event.sender.expectPrincipal(sender);\n      if (event.ft_burn_event.asset_identifier.endsWith(assetId)) {\n        e[\"assetId\"] = event.ft_burn_event.asset_identifier;\n      } else {\n        continue;\n      }\n      return e;\n    } catch (error) {\n      continue;\n    }\n  }\n  throw new Error(`Unable to retrieve expected FungibleTokenBurnEvent`);\n};\n\nArray.prototype.expectPrintEvent = function (\n  contract_identifier: string,\n  value: string,\n) {\n  for (let event of this) {\n    try {\n      let e: any = {};\n      e[\"contract_identifier\"] = event.contract_event.contract_identifier\n        .expectPrincipal(\n          contract_identifier,\n        );\n\n      if (event.contract_event.topic.endsWith(\"print\")) {\n        e[\"topic\"] = event.contract_event.topic;\n      } else {\n        continue;\n      }\n\n      if (event.contract_event.value.endsWith(value)) {\n        e[\"value\"] = event.contract_event.value;\n      } else {\n        continue;\n      }\n      return e;\n    } catch (error) {\n      continue;\n    }\n  }\n  throw new Error(`Unable to retrieve expected PrintEvent`);\n};\n// Array.prototype.expectEvent = function(sel: (e: Object) => Object) {\n//     for (let event of this) {\n//         try {\n//             sel(event);\n//             return event as Object;\n//         } catch (error) {\n//             continue;\n//         }\n//     }\n//     throw new Error(`Unable to retrieve expected PrintEvent`);\n// }\nArray.prototype.expectNonFungibleTokenTransferEvent = function (\n  tokenId: String,\n  sender: String,\n  recipient: String,\n  assetAddress: String,\n  assetId: String,\n) {\n  for (let event of this) {\n    try {\n      let e: any = {};\n      if (event.nft_transfer_event.value === tokenId) {\n        e[\"tokenId\"] = event.nft_transfer_event.value;\n      } else {\n        continue;\n      }\n      e[\"sender\"] = event.nft_transfer_event.sender.expectPrincipal(sender);\n      e[\"recipient\"] = event.nft_transfer_event.recipient.expectPrincipal(\n        recipient,\n      );\n      if (\n        event.nft_transfer_event.asset_identifier ===\n          `${assetAddress}::${assetId}`\n      ) {\n        e[\"assetId\"] = event.nft_transfer_event.asset_identifier;\n      } else {\n        continue;\n      }\n      return e;\n    } catch (error) {\n      continue;\n    }\n  }\n  throw new Error(`Unable to retrieve expected NonFungibleTokenTransferEvent`);\n};\n\nArray.prototype.expectNonFungibleTokenMintEvent = function (\n  tokenId: String,\n  recipient: String,\n  assetAddress: String,\n  assetId: String,\n) {\n  for (let event of this) {\n    try {\n      let e: any = {};\n      if (event.nft_mint_event.value === tokenId) {\n        e[\"tokenId\"] = event.nft_mint_event.value;\n      } else {\n        continue;\n      }\n      e[\"recipient\"] = event.nft_mint_event.recipient.expectPrincipal(\n        recipient,\n      );\n      if (\n        event.nft_mint_event.asset_identifier === `${assetAddress}::${assetId}`\n      ) {\n        e[\"assetId\"] = event.nft_mint_event.asset_identifier;\n      } else {\n        continue;\n      }\n      return e;\n    } catch (error) {\n      continue;\n    }\n  }\n  throw new Error(`Unable to retrieve expected NonFungibleTokenMintEvent`);\n};\n\nArray.prototype.expectNonFungibleTokenBurnEvent = function (\n  tokenId: String,\n  sender: String,\n  assetAddress: String,\n  assetId: String,\n) {\n  for (let event of this) {\n    try {\n      let e: any = {};\n      if (event.nft_burn_event.value === tokenId) {\n        e[\"tokenId\"] = event.nft_burn_event.value;\n      } else {\n        continue;\n      }\n      e[\"sender\"] = event.nft_burn_event.sender.expectPrincipal(sender);\n      if (\n        event.nft_burn_event.asset_identifier === `${assetAddress}::${assetId}`\n      ) {\n        e[\"assetId\"] = event.nft_burn_event.asset_identifier;\n      } else {\n        continue;\n      }\n      return e;\n    } catch (error) {\n      continue;\n    }\n  }\n  throw new Error(`Unable to retrieve expected NonFungibleTokenBurnEvent`);\n};\n\nconst noColor = globalThis.Deno?.noColor ?? true;\n\ninterface Code {\n  open: string;\n  close: string;\n  regexp: RegExp;\n}\n\nlet enabled = !noColor;\n\nfunction code(open: number[], close: number): Code {\n  return {\n    open: `\\x1b[${open.join(\";\")}m`,\n    close: `\\x1b[${close}m`,\n    regexp: new RegExp(`\\\\x1b\\\\[${close}m`, \"g\"),\n  };\n}\n\nfunction run(str: string, code: Code): string {\n  return enabled\n    ? `${code.open}${str.replace(code.regexp, code.open)}${code.close}`\n    : str;\n}\n\nexport function red(str: string): string {\n  return run(str, code([31], 39));\n}\n\nexport function green(str: string): string {\n  return run(str, code([32], 39));\n}\n"],"names":[],"mappings":"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"} \ No newline at end of file diff --git "a/.\\.cache/gen/https/deno.land/7c02e05b5297e003cb3d3ca5a0297c761a2f3a683dbb03ff3a1380681fcb8d54.meta" "b/.\\.cache/gen/https/deno.land/7c02e05b5297e003cb3d3ca5a0297c761a2f3a683dbb03ff3a1380681fcb8d54.meta" deleted file mode 100644 index 7975923..0000000 --- "a/.\\.cache/gen/https/deno.land/7c02e05b5297e003cb3d3ca5a0297c761a2f3a683dbb03ff3a1380681fcb8d54.meta" +++ /dev/null @@ -1 +0,0 @@ -{"source_hash":"1067396034229057420","emit_hash":"13598205218251017875"} \ No newline at end of file diff --git "a/.\\.cache/gen/https/deno.land/b74532b63b4b2b08e618f6ccbb6ec181293852d7b2c4aea34cb1599ab82741d4.js" "b/.\\.cache/gen/https/deno.land/b74532b63b4b2b08e618f6ccbb6ec181293852d7b2c4aea34cb1599ab82741d4.js" deleted file mode 100644 index 602d9c8..0000000 --- "a/.\\.cache/gen/https/deno.land/b74532b63b4b2b08e618f6ccbb6ec181293852d7b2c4aea34cb1599ab82741d4.js" +++ /dev/null @@ -1,178 +0,0 @@ -export var DiffType; -(function(DiffType) { - DiffType["removed"] = "removed"; - DiffType["common"] = "common"; - DiffType["added"] = "added"; -})(DiffType || (DiffType = {})); -const REMOVED = 1; -const COMMON = 2; -const ADDED = 3; -function createCommon(A, B, reverse) { - const common = []; - if (A.length === 0 || B.length === 0) return []; - for(let i = 0; i < Math.min(A.length, B.length); i += 1){ - if (A[reverse ? A.length - i - 1 : i] === B[reverse ? B.length - i - 1 : i]) { - common.push(A[reverse ? A.length - i - 1 : i]); - } else { - return common; - } - } - return common; -} -/** - * Renders the differences between the actual and expected values - * @param A Actual value - * @param B Expected value - */ export function diff(A, B) { - const prefixCommon = createCommon(A, B); - const suffixCommon = createCommon(A.slice(prefixCommon.length), B.slice(prefixCommon.length), true).reverse(); - A = suffixCommon.length ? A.slice(prefixCommon.length, -suffixCommon.length) : A.slice(prefixCommon.length); - B = suffixCommon.length ? B.slice(prefixCommon.length, -suffixCommon.length) : B.slice(prefixCommon.length); - const swapped = B.length > A.length; - [A, B] = swapped ? [ - B, - A - ] : [ - A, - B - ]; - const M = A.length; - const N = B.length; - if (!M && !N && !suffixCommon.length && !prefixCommon.length) return []; - if (!N) { - return [ - ...prefixCommon.map((c)=>({ - type: DiffType.common, - value: c - })), - ...A.map((a)=>({ - type: swapped ? DiffType.added : DiffType.removed, - value: a - })), - ...suffixCommon.map((c)=>({ - type: DiffType.common, - value: c - })), - ]; - } - const offset = N; - const delta = M - N; - const size = M + N + 1; - const fp = new Array(size).fill({ - y: -1 - }); - /** - * INFO: - * This buffer is used to save memory and improve performance. - * The first half is used to save route and last half is used to save diff - * type. - * This is because, when I kept new uint8array area to save type,performance - * worsened. - */ const routes = new Uint32Array((M * N + size + 1) * 2); - const diffTypesPtrOffset = routes.length / 2; - let ptr = 0; - let p = -1; - function backTrace(A, B, current, swapped) { - const M = A.length; - const N = B.length; - const result = []; - let a = M - 1; - let b = N - 1; - let j = routes[current.id]; - let type = routes[current.id + diffTypesPtrOffset]; - while(true){ - if (!j && !type) break; - const prev = j; - if (type === REMOVED) { - result.unshift({ - type: swapped ? DiffType.removed : DiffType.added, - value: B[b] - }); - b -= 1; - } else if (type === ADDED) { - result.unshift({ - type: swapped ? DiffType.added : DiffType.removed, - value: A[a] - }); - a -= 1; - } else { - result.unshift({ - type: DiffType.common, - value: A[a] - }); - a -= 1; - b -= 1; - } - j = routes[prev]; - type = routes[prev + diffTypesPtrOffset]; - } - return result; - } - function createFP(slide, down, k, M) { - if (slide && slide.y === -1 && down && down.y === -1) { - return { - y: 0, - id: 0 - }; - } - if (down && down.y === -1 || k === M || (slide && slide.y) > (down && down.y) + 1) { - const prev = slide.id; - ptr++; - routes[ptr] = prev; - routes[ptr + diffTypesPtrOffset] = ADDED; - return { - y: slide.y, - id: ptr - }; - } else { - const prev1 = down.id; - ptr++; - routes[ptr] = prev1; - routes[ptr + diffTypesPtrOffset] = REMOVED; - return { - y: down.y + 1, - id: ptr - }; - } - } - function snake(k, slide, down, _offset, A, B) { - const M = A.length; - const N = B.length; - if (k < -N || M < k) return { - y: -1, - id: -1 - }; - const fp = createFP(slide, down, k, M); - while(fp.y + k < M && fp.y < N && A[fp.y + k] === B[fp.y]){ - const prev = fp.id; - ptr++; - fp.id = ptr; - fp.y += 1; - routes[ptr] = prev; - routes[ptr + diffTypesPtrOffset] = COMMON; - } - return fp; - } - while(fp[delta + offset].y < N){ - p = p + 1; - for(let k = -p; k < delta; ++k){ - fp[k + offset] = snake(k, fp[k - 1 + offset], fp[k + 1 + offset], offset, A, B); - } - for(let k1 = delta + p; k1 > delta; --k1){ - fp[k1 + offset] = snake(k1, fp[k1 - 1 + offset], fp[k1 + 1 + offset], offset, A, B); - } - fp[delta + offset] = snake(delta, fp[delta - 1 + offset], fp[delta + 1 + offset], offset, A, B); - } - return [ - ...prefixCommon.map((c)=>({ - type: DiffType.common, - value: c - })), - ...backTrace(A, B, fp[delta + offset], swapped), - ...suffixCommon.map((c)=>({ - type: DiffType.common, - value: c - })), - ]; -} -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["https://deno.land/std@0.90.0/testing/_diff.ts"],"sourcesContent":["// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.\n// This module is browser compatible.\n\ninterface FarthestPoint {\n  y: number;\n  id: number;\n}\n\nexport enum DiffType {\n  removed = \"removed\",\n  common = \"common\",\n  added = \"added\",\n}\n\nexport interface DiffResult<T> {\n  type: DiffType;\n  value: T;\n}\n\nconst REMOVED = 1;\nconst COMMON = 2;\nconst ADDED = 3;\n\nfunction createCommon<T>(A: T[], B: T[], reverse?: boolean): T[] {\n  const common = [];\n  if (A.length === 0 || B.length === 0) return [];\n  for (let i = 0; i < Math.min(A.length, B.length); i += 1) {\n    if (\n      A[reverse ? A.length - i - 1 : i] === B[reverse ? B.length - i - 1 : i]\n    ) {\n      common.push(A[reverse ? A.length - i - 1 : i]);\n    } else {\n      return common;\n    }\n  }\n  return common;\n}\n\n/**\n * Renders the differences between the actual and expected values\n * @param A Actual value\n * @param B Expected value\n */\nexport function diff<T>(A: T[], B: T[]): Array<DiffResult<T>> {\n  const prefixCommon = createCommon(A, B);\n  const suffixCommon = createCommon(\n    A.slice(prefixCommon.length),\n    B.slice(prefixCommon.length),\n    true,\n  ).reverse();\n  A = suffixCommon.length\n    ? A.slice(prefixCommon.length, -suffixCommon.length)\n    : A.slice(prefixCommon.length);\n  B = suffixCommon.length\n    ? B.slice(prefixCommon.length, -suffixCommon.length)\n    : B.slice(prefixCommon.length);\n  const swapped = B.length > A.length;\n  [A, B] = swapped ? [B, A] : [A, B];\n  const M = A.length;\n  const N = B.length;\n  if (!M && !N && !suffixCommon.length && !prefixCommon.length) return [];\n  if (!N) {\n    return [\n      ...prefixCommon.map(\n        (c): DiffResult<typeof c> => ({ type: DiffType.common, value: c }),\n      ),\n      ...A.map(\n        (a): DiffResult<typeof a> => ({\n          type: swapped ? DiffType.added : DiffType.removed,\n          value: a,\n        }),\n      ),\n      ...suffixCommon.map(\n        (c): DiffResult<typeof c> => ({ type: DiffType.common, value: c }),\n      ),\n    ];\n  }\n  const offset = N;\n  const delta = M - N;\n  const size = M + N + 1;\n  const fp = new Array(size).fill({ y: -1 });\n  /**\n   * INFO:\n   * This buffer is used to save memory and improve performance.\n   * The first half is used to save route and last half is used to save diff\n   * type.\n   * This is because, when I kept new uint8array area to save type,performance\n   * worsened.\n   */\n  const routes = new Uint32Array((M * N + size + 1) * 2);\n  const diffTypesPtrOffset = routes.length / 2;\n  let ptr = 0;\n  let p = -1;\n\n  function backTrace<T>(\n    A: T[],\n    B: T[],\n    current: FarthestPoint,\n    swapped: boolean,\n  ): Array<{\n    type: DiffType;\n    value: T;\n  }> {\n    const M = A.length;\n    const N = B.length;\n    const result = [];\n    let a = M - 1;\n    let b = N - 1;\n    let j = routes[current.id];\n    let type = routes[current.id + diffTypesPtrOffset];\n    while (true) {\n      if (!j && !type) break;\n      const prev = j;\n      if (type === REMOVED) {\n        result.unshift({\n          type: swapped ? DiffType.removed : DiffType.added,\n          value: B[b],\n        });\n        b -= 1;\n      } else if (type === ADDED) {\n        result.unshift({\n          type: swapped ? DiffType.added : DiffType.removed,\n          value: A[a],\n        });\n        a -= 1;\n      } else {\n        result.unshift({ type: DiffType.common, value: A[a] });\n        a -= 1;\n        b -= 1;\n      }\n      j = routes[prev];\n      type = routes[prev + diffTypesPtrOffset];\n    }\n    return result;\n  }\n\n  function createFP(\n    slide: FarthestPoint,\n    down: FarthestPoint,\n    k: number,\n    M: number,\n  ): FarthestPoint {\n    if (slide && slide.y === -1 && down && down.y === -1) {\n      return { y: 0, id: 0 };\n    }\n    if (\n      (down && down.y === -1) ||\n      k === M ||\n      (slide && slide.y) > (down && down.y) + 1\n    ) {\n      const prev = slide.id;\n      ptr++;\n      routes[ptr] = prev;\n      routes[ptr + diffTypesPtrOffset] = ADDED;\n      return { y: slide.y, id: ptr };\n    } else {\n      const prev = down.id;\n      ptr++;\n      routes[ptr] = prev;\n      routes[ptr + diffTypesPtrOffset] = REMOVED;\n      return { y: down.y + 1, id: ptr };\n    }\n  }\n\n  function snake<T>(\n    k: number,\n    slide: FarthestPoint,\n    down: FarthestPoint,\n    _offset: number,\n    A: T[],\n    B: T[],\n  ): FarthestPoint {\n    const M = A.length;\n    const N = B.length;\n    if (k < -N || M < k) return { y: -1, id: -1 };\n    const fp = createFP(slide, down, k, M);\n    while (fp.y + k < M && fp.y < N && A[fp.y + k] === B[fp.y]) {\n      const prev = fp.id;\n      ptr++;\n      fp.id = ptr;\n      fp.y += 1;\n      routes[ptr] = prev;\n      routes[ptr + diffTypesPtrOffset] = COMMON;\n    }\n    return fp;\n  }\n\n  while (fp[delta + offset].y < N) {\n    p = p + 1;\n    for (let k = -p; k < delta; ++k) {\n      fp[k + offset] = snake(\n        k,\n        fp[k - 1 + offset],\n        fp[k + 1 + offset],\n        offset,\n        A,\n        B,\n      );\n    }\n    for (let k = delta + p; k > delta; --k) {\n      fp[k + offset] = snake(\n        k,\n        fp[k - 1 + offset],\n        fp[k + 1 + offset],\n        offset,\n        A,\n        B,\n      );\n    }\n    fp[delta + offset] = snake(\n      delta,\n      fp[delta - 1 + offset],\n      fp[delta + 1 + offset],\n      offset,\n      A,\n      B,\n    );\n  }\n  return [\n    ...prefixCommon.map(\n      (c): DiffResult<typeof c> => ({ type: DiffType.common, value: c }),\n    ),\n    ...backTrace(A, B, fp[delta + offset], swapped),\n    ...suffixCommon.map(\n      (c): DiffResult<typeof c> => ({ type: DiffType.common, value: c }),\n    ),\n  ];\n}\n"],"names":[],"mappings":"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"} \ No newline at end of file diff --git "a/.\\.cache/gen/https/deno.land/b74532b63b4b2b08e618f6ccbb6ec181293852d7b2c4aea34cb1599ab82741d4.meta" "b/.\\.cache/gen/https/deno.land/b74532b63b4b2b08e618f6ccbb6ec181293852d7b2c4aea34cb1599ab82741d4.meta" deleted file mode 100644 index 4b36acd..0000000 --- "a/.\\.cache/gen/https/deno.land/b74532b63b4b2b08e618f6ccbb6ec181293852d7b2c4aea34cb1599ab82741d4.meta" +++ /dev/null @@ -1 +0,0 @@ -{"source_hash":"14728771330113844916","emit_hash":"17537645386804052"} \ No newline at end of file diff --git "a/.\\.cache/gen/https/deno.land/c3031fe6d1ec46c7ee6519cd64b11875eca3b83ce3ceb1323a43a0810846f180.js" "b/.\\.cache/gen/https/deno.land/c3031fe6d1ec46c7ee6519cd64b11875eca3b83ce3ceb1323a43a0810846f180.js" deleted file mode 100644 index 32bcc6f..0000000 --- "a/.\\.cache/gen/https/deno.land/c3031fe6d1ec46c7ee6519cd64b11875eca3b83ce3ceb1323a43a0810846f180.js" +++ /dev/null @@ -1,473 +0,0 @@ -// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. -// A module to print ANSI terminal colors. Inspired by chalk, kleur, and colors -// on npm. -// -// ``` -// import { bgBlue, red, bold } from "https://deno.land/std/fmt/colors.ts"; -// console.log(bgBlue(red(bold("Hello world!")))); -// ``` -// -// This module supports `NO_COLOR` environmental variable disabling any coloring -// if `NO_COLOR` is set. -// -// This module is browser compatible. -const noColor = globalThis.Deno?.noColor ?? true; -let enabled = !noColor; -/** - * Set changing text color to enabled or disabled - * @param value - */ export function setColorEnabled(value) { - if (noColor) { - return; - } - enabled = value; -} -/** Get whether text color change is enabled or disabled. */ export function getColorEnabled() { - return enabled; -} -/** - * Builds color code - * @param open - * @param close - */ function code(open, close) { - return { - open: `\x1b[${open.join(";")}m`, - close: `\x1b[${close}m`, - regexp: new RegExp(`\\x1b\\[${close}m`, "g") - }; -} -/** - * Applies color and background based on color code and its associated text - * @param str text to apply color settings to - * @param code color code to apply - */ function run(str, code) { - return enabled ? `${code.open}${str.replace(code.regexp, code.open)}${code.close}` : str; -} -/** - * Reset the text modified - * @param str text to reset - */ export function reset(str) { - return run(str, code([ - 0 - ], 0)); -} -/** - * Make the text bold. - * @param str text to make bold - */ export function bold(str) { - return run(str, code([ - 1 - ], 22)); -} -/** - * The text emits only a small amount of light. - * @param str text to dim - */ export function dim(str) { - return run(str, code([ - 2 - ], 22)); -} -/** - * Make the text italic. - * @param str text to make italic - */ export function italic(str) { - return run(str, code([ - 3 - ], 23)); -} -/** - * Make the text underline. - * @param str text to underline - */ export function underline(str) { - return run(str, code([ - 4 - ], 24)); -} -/** - * Invert background color and text color. - * @param str text to invert its color - */ export function inverse(str) { - return run(str, code([ - 7 - ], 27)); -} -/** - * Make the text hidden. - * @param str text to hide - */ export function hidden(str) { - return run(str, code([ - 8 - ], 28)); -} -/** - * Put horizontal line through the center of the text. - * @param str text to strike through - */ export function strikethrough(str) { - return run(str, code([ - 9 - ], 29)); -} -/** - * Set text color to black. - * @param str text to make black - */ export function black(str) { - return run(str, code([ - 30 - ], 39)); -} -/** - * Set text color to red. - * @param str text to make red - */ export function red(str) { - return run(str, code([ - 31 - ], 39)); -} -/** - * Set text color to green. - * @param str text to make green - */ export function green(str) { - return run(str, code([ - 32 - ], 39)); -} -/** - * Set text color to yellow. - * @param str text to make yellow - */ export function yellow(str) { - return run(str, code([ - 33 - ], 39)); -} -/** - * Set text color to blue. - * @param str text to make blue - */ export function blue(str) { - return run(str, code([ - 34 - ], 39)); -} -/** - * Set text color to magenta. - * @param str text to make magenta - */ export function magenta(str) { - return run(str, code([ - 35 - ], 39)); -} -/** - * Set text color to cyan. - * @param str text to make cyan - */ export function cyan(str) { - return run(str, code([ - 36 - ], 39)); -} -/** - * Set text color to white. - * @param str text to make white - */ export function white(str) { - return run(str, code([ - 37 - ], 39)); -} -/** - * Set text color to gray. - * @param str text to make gray - */ export function gray(str) { - return brightBlack(str); -} -/** - * Set text color to bright black. - * @param str text to make bright-black - */ export function brightBlack(str) { - return run(str, code([ - 90 - ], 39)); -} -/** - * Set text color to bright red. - * @param str text to make bright-red - */ export function brightRed(str) { - return run(str, code([ - 91 - ], 39)); -} -/** - * Set text color to bright green. - * @param str text to make bright-green - */ export function brightGreen(str) { - return run(str, code([ - 92 - ], 39)); -} -/** - * Set text color to bright yellow. - * @param str text to make bright-yellow - */ export function brightYellow(str) { - return run(str, code([ - 93 - ], 39)); -} -/** - * Set text color to bright blue. - * @param str text to make bright-blue - */ export function brightBlue(str) { - return run(str, code([ - 94 - ], 39)); -} -/** - * Set text color to bright magenta. - * @param str text to make bright-magenta - */ export function brightMagenta(str) { - return run(str, code([ - 95 - ], 39)); -} -/** - * Set text color to bright cyan. - * @param str text to make bright-cyan - */ export function brightCyan(str) { - return run(str, code([ - 96 - ], 39)); -} -/** - * Set text color to bright white. - * @param str text to make bright-white - */ export function brightWhite(str) { - return run(str, code([ - 97 - ], 39)); -} -/** - * Set background color to black. - * @param str text to make its background black - */ export function bgBlack(str) { - return run(str, code([ - 40 - ], 49)); -} -/** - * Set background color to red. - * @param str text to make its background red - */ export function bgRed(str) { - return run(str, code([ - 41 - ], 49)); -} -/** - * Set background color to green. - * @param str text to make its background green - */ export function bgGreen(str) { - return run(str, code([ - 42 - ], 49)); -} -/** - * Set background color to yellow. - * @param str text to make its background yellow - */ export function bgYellow(str) { - return run(str, code([ - 43 - ], 49)); -} -/** - * Set background color to blue. - * @param str text to make its background blue - */ export function bgBlue(str) { - return run(str, code([ - 44 - ], 49)); -} -/** - * Set background color to magenta. - * @param str text to make its background magenta - */ export function bgMagenta(str) { - return run(str, code([ - 45 - ], 49)); -} -/** - * Set background color to cyan. - * @param str text to make its background cyan - */ export function bgCyan(str) { - return run(str, code([ - 46 - ], 49)); -} -/** - * Set background color to white. - * @param str text to make its background white - */ export function bgWhite(str) { - return run(str, code([ - 47 - ], 49)); -} -/** - * Set background color to bright black. - * @param str text to make its background bright-black - */ export function bgBrightBlack(str) { - return run(str, code([ - 100 - ], 49)); -} -/** - * Set background color to bright red. - * @param str text to make its background bright-red - */ export function bgBrightRed(str) { - return run(str, code([ - 101 - ], 49)); -} -/** - * Set background color to bright green. - * @param str text to make its background bright-green - */ export function bgBrightGreen(str) { - return run(str, code([ - 102 - ], 49)); -} -/** - * Set background color to bright yellow. - * @param str text to make its background bright-yellow - */ export function bgBrightYellow(str) { - return run(str, code([ - 103 - ], 49)); -} -/** - * Set background color to bright blue. - * @param str text to make its background bright-blue - */ export function bgBrightBlue(str) { - return run(str, code([ - 104 - ], 49)); -} -/** - * Set background color to bright magenta. - * @param str text to make its background bright-magenta - */ export function bgBrightMagenta(str) { - return run(str, code([ - 105 - ], 49)); -} -/** - * Set background color to bright cyan. - * @param str text to make its background bright-cyan - */ export function bgBrightCyan(str) { - return run(str, code([ - 106 - ], 49)); -} -/** - * Set background color to bright white. - * @param str text to make its background bright-white - */ export function bgBrightWhite(str) { - return run(str, code([ - 107 - ], 49)); -} -/* Special Color Sequences */ /** - * Clam and truncate color codes - * @param n - * @param max number to truncate to - * @param min number to truncate from - */ function clampAndTruncate(n, max = 255, min = 0) { - return Math.trunc(Math.max(Math.min(n, max), min)); -} -/** - * Set text color using paletted 8bit colors. - * https://en.wikipedia.org/wiki/ANSI_escape_code#8-bit - * @param str text color to apply paletted 8bit colors to - * @param color code - */ export function rgb8(str, color) { - return run(str, code([ - 38, - 5, - clampAndTruncate(color) - ], 39)); -} -/** - * Set background color using paletted 8bit colors. - * https://en.wikipedia.org/wiki/ANSI_escape_code#8-bit - * @param str text color to apply paletted 8bit background colors to - * @param color code - */ export function bgRgb8(str, color) { - return run(str, code([ - 48, - 5, - clampAndTruncate(color) - ], 49)); -} -/** - * Set text color using 24bit rgb. - * `color` can be a number in range `0x000000` to `0xffffff` or - * an `Rgb`. - * - * To produce the color magenta: - * - * rgb24("foo", 0xff00ff); - * rgb24("foo", {r: 255, g: 0, b: 255}); - * @param str text color to apply 24bit rgb to - * @param color code - */ export function rgb24(str, color) { - if (typeof color === "number") { - return run(str, code([ - 38, - 2, - color >> 16 & 0xff, - color >> 8 & 0xff, - color & 0xff - ], 39)); - } - return run(str, code([ - 38, - 2, - clampAndTruncate(color.r), - clampAndTruncate(color.g), - clampAndTruncate(color.b), - ], 39)); -} -/** - * Set background color using 24bit rgb. - * `color` can be a number in range `0x000000` to `0xffffff` or - * an `Rgb`. - * - * To produce the color magenta: - * - * bgRgb24("foo", 0xff00ff); - * bgRgb24("foo", {r: 255, g: 0, b: 255}); - * @param str text color to apply 24bit rgb to - * @param color code - */ export function bgRgb24(str, color) { - if (typeof color === "number") { - return run(str, code([ - 48, - 2, - color >> 16 & 0xff, - color >> 8 & 0xff, - color & 0xff - ], 49)); - } - return run(str, code([ - 48, - 2, - clampAndTruncate(color.r), - clampAndTruncate(color.g), - clampAndTruncate(color.b), - ], 49)); -} -// https://github.com/chalk/ansi-regex/blob/2b56fb0c7a07108e5b54241e8faec160d393aedb/index.js -const ANSI_PATTERN = new RegExp([ - "[\\u001B\\u009B][[\\]()#;?]*(?:(?:(?:[a-zA-Z\\d]*(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]*)*)?\\u0007)", - "(?:(?:\\d{1,4}(?:;\\d{0,4})*)?[\\dA-PR-TZcf-ntqry=><~]))", -].join("|"), "g"); -/** - * Remove ANSI escape codes from the string. - * @param string to remove ANSI escape codes from - */ export function stripColor(string) { - return string.replace(ANSI_PATTERN, ""); -} -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["https://deno.land/std@0.90.0/fmt/colors.ts"],"sourcesContent":["// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.\n// A module to print ANSI terminal colors. Inspired by chalk, kleur, and colors\n// on npm.\n//\n// ```\n// import { bgBlue, red, bold } from \"https://deno.land/std/fmt/colors.ts\";\n// console.log(bgBlue(red(bold(\"Hello world!\"))));\n// ```\n//\n// This module supports `NO_COLOR` environmental variable disabling any coloring\n// if `NO_COLOR` is set.\n//\n// This module is browser compatible.\n\nconst noColor = globalThis.Deno?.noColor ?? true;\n\ninterface Code {\n  open: string;\n  close: string;\n  regexp: RegExp;\n}\n\n/** RGB 8-bits per channel. Each in range `0->255` or `0x00->0xff` */\ninterface Rgb {\n  r: number;\n  g: number;\n  b: number;\n}\n\nlet enabled = !noColor;\n\n/**\n * Set changing text color to enabled or disabled\n * @param value\n */\nexport function setColorEnabled(value: boolean): void {\n  if (noColor) {\n    return;\n  }\n\n  enabled = value;\n}\n\n/** Get whether text color change is enabled or disabled. */\nexport function getColorEnabled(): boolean {\n  return enabled;\n}\n\n/**\n * Builds color code\n * @param open\n * @param close\n */\nfunction code(open: number[], close: number): Code {\n  return {\n    open: `\\x1b[${open.join(\";\")}m`,\n    close: `\\x1b[${close}m`,\n    regexp: new RegExp(`\\\\x1b\\\\[${close}m`, \"g\"),\n  };\n}\n\n/**\n * Applies color and background based on color code and its associated text\n * @param str text to apply color settings to\n * @param code color code to apply\n */\nfunction run(str: string, code: Code): string {\n  return enabled\n    ? `${code.open}${str.replace(code.regexp, code.open)}${code.close}`\n    : str;\n}\n\n/**\n * Reset the text modified\n * @param str text to reset\n */\nexport function reset(str: string): string {\n  return run(str, code([0], 0));\n}\n\n/**\n * Make the text bold.\n * @param str text to make bold\n */\nexport function bold(str: string): string {\n  return run(str, code([1], 22));\n}\n\n/**\n * The text emits only a small amount of light.\n * @param str text to dim\n */\nexport function dim(str: string): string {\n  return run(str, code([2], 22));\n}\n\n/**\n * Make the text italic.\n * @param str text to make italic\n */\nexport function italic(str: string): string {\n  return run(str, code([3], 23));\n}\n\n/**\n * Make the text underline.\n * @param str text to underline\n */\nexport function underline(str: string): string {\n  return run(str, code([4], 24));\n}\n\n/**\n * Invert background color and text color.\n * @param str text to invert its color\n */\nexport function inverse(str: string): string {\n  return run(str, code([7], 27));\n}\n\n/**\n * Make the text hidden.\n * @param str text to hide\n */\nexport function hidden(str: string): string {\n  return run(str, code([8], 28));\n}\n\n/**\n * Put horizontal line through the center of the text.\n * @param str text to strike through\n */\nexport function strikethrough(str: string): string {\n  return run(str, code([9], 29));\n}\n\n/**\n * Set text color to black.\n * @param str text to make black\n */\nexport function black(str: string): string {\n  return run(str, code([30], 39));\n}\n\n/**\n * Set text color to red.\n * @param str text to make red\n */\nexport function red(str: string): string {\n  return run(str, code([31], 39));\n}\n\n/**\n * Set text color to green.\n * @param str text to make green\n */\nexport function green(str: string): string {\n  return run(str, code([32], 39));\n}\n\n/**\n * Set text color to yellow.\n * @param str text to make yellow\n */\nexport function yellow(str: string): string {\n  return run(str, code([33], 39));\n}\n\n/**\n * Set text color to blue.\n * @param str text to make blue\n */\nexport function blue(str: string): string {\n  return run(str, code([34], 39));\n}\n\n/**\n * Set text color to magenta.\n * @param str text to make magenta\n */\nexport function magenta(str: string): string {\n  return run(str, code([35], 39));\n}\n\n/**\n * Set text color to cyan.\n * @param str text to make cyan\n */\nexport function cyan(str: string): string {\n  return run(str, code([36], 39));\n}\n\n/**\n * Set text color to white.\n * @param str text to make white\n */\nexport function white(str: string): string {\n  return run(str, code([37], 39));\n}\n\n/**\n * Set text color to gray.\n * @param str text to make gray\n */\nexport function gray(str: string): string {\n  return brightBlack(str);\n}\n\n/**\n * Set text color to bright black.\n * @param str text to make bright-black\n */\nexport function brightBlack(str: string): string {\n  return run(str, code([90], 39));\n}\n\n/**\n * Set text color to bright red.\n * @param str text to make bright-red\n */\nexport function brightRed(str: string): string {\n  return run(str, code([91], 39));\n}\n\n/**\n * Set text color to bright green.\n * @param str text to make bright-green\n */\nexport function brightGreen(str: string): string {\n  return run(str, code([92], 39));\n}\n\n/**\n * Set text color to bright yellow.\n * @param str text to make bright-yellow\n */\nexport function brightYellow(str: string): string {\n  return run(str, code([93], 39));\n}\n\n/**\n * Set text color to bright blue.\n * @param str text to make bright-blue\n */\nexport function brightBlue(str: string): string {\n  return run(str, code([94], 39));\n}\n\n/**\n * Set text color to bright magenta.\n * @param str text to make bright-magenta\n */\nexport function brightMagenta(str: string): string {\n  return run(str, code([95], 39));\n}\n\n/**\n * Set text color to bright cyan.\n * @param str text to make bright-cyan\n */\nexport function brightCyan(str: string): string {\n  return run(str, code([96], 39));\n}\n\n/**\n * Set text color to bright white.\n * @param str text to make bright-white\n */\nexport function brightWhite(str: string): string {\n  return run(str, code([97], 39));\n}\n\n/**\n * Set background color to black.\n * @param str text to make its background black\n */\nexport function bgBlack(str: string): string {\n  return run(str, code([40], 49));\n}\n\n/**\n * Set background color to red.\n * @param str text to make its background red\n */\nexport function bgRed(str: string): string {\n  return run(str, code([41], 49));\n}\n\n/**\n * Set background color to green.\n * @param str text to make its background green\n */\nexport function bgGreen(str: string): string {\n  return run(str, code([42], 49));\n}\n\n/**\n * Set background color to yellow.\n * @param str text to make its background yellow\n */\nexport function bgYellow(str: string): string {\n  return run(str, code([43], 49));\n}\n\n/**\n * Set background color to blue.\n * @param str text to make its background blue\n */\nexport function bgBlue(str: string): string {\n  return run(str, code([44], 49));\n}\n\n/**\n *  Set background color to magenta.\n * @param str text to make its background magenta\n */\nexport function bgMagenta(str: string): string {\n  return run(str, code([45], 49));\n}\n\n/**\n * Set background color to cyan.\n * @param str text to make its background cyan\n */\nexport function bgCyan(str: string): string {\n  return run(str, code([46], 49));\n}\n\n/**\n * Set background color to white.\n * @param str text to make its background white\n */\nexport function bgWhite(str: string): string {\n  return run(str, code([47], 49));\n}\n\n/**\n * Set background color to bright black.\n * @param str text to make its background bright-black\n */\nexport function bgBrightBlack(str: string): string {\n  return run(str, code([100], 49));\n}\n\n/**\n * Set background color to bright red.\n * @param str text to make its background bright-red\n */\nexport function bgBrightRed(str: string): string {\n  return run(str, code([101], 49));\n}\n\n/**\n * Set background color to bright green.\n * @param str text to make its background bright-green\n */\nexport function bgBrightGreen(str: string): string {\n  return run(str, code([102], 49));\n}\n\n/**\n * Set background color to bright yellow.\n * @param str text to make its background bright-yellow\n */\nexport function bgBrightYellow(str: string): string {\n  return run(str, code([103], 49));\n}\n\n/**\n * Set background color to bright blue.\n * @param str text to make its background bright-blue\n */\nexport function bgBrightBlue(str: string): string {\n  return run(str, code([104], 49));\n}\n\n/**\n * Set background color to bright magenta.\n * @param str text to make its background bright-magenta\n */\nexport function bgBrightMagenta(str: string): string {\n  return run(str, code([105], 49));\n}\n\n/**\n * Set background color to bright cyan.\n * @param str text to make its background bright-cyan\n */\nexport function bgBrightCyan(str: string): string {\n  return run(str, code([106], 49));\n}\n\n/**\n * Set background color to bright white.\n * @param str text to make its background bright-white\n */\nexport function bgBrightWhite(str: string): string {\n  return run(str, code([107], 49));\n}\n\n/* Special Color Sequences */\n\n/**\n * Clam and truncate color codes\n * @param n\n * @param max number to truncate to\n * @param min number to truncate from\n */\nfunction clampAndTruncate(n: number, max = 255, min = 0): number {\n  return Math.trunc(Math.max(Math.min(n, max), min));\n}\n\n/**\n * Set text color using paletted 8bit colors.\n * https://en.wikipedia.org/wiki/ANSI_escape_code#8-bit\n * @param str text color to apply paletted 8bit colors to\n * @param color code\n */\nexport function rgb8(str: string, color: number): string {\n  return run(str, code([38, 5, clampAndTruncate(color)], 39));\n}\n\n/**\n * Set background color using paletted 8bit colors.\n * https://en.wikipedia.org/wiki/ANSI_escape_code#8-bit\n * @param str text color to apply paletted 8bit background colors to\n * @param color code\n */\nexport function bgRgb8(str: string, color: number): string {\n  return run(str, code([48, 5, clampAndTruncate(color)], 49));\n}\n\n/**\n * Set text color using 24bit rgb.\n * `color` can be a number in range `0x000000` to `0xffffff` or\n * an `Rgb`.\n *\n * To produce the color magenta:\n *\n *      rgb24(\"foo\", 0xff00ff);\n *      rgb24(\"foo\", {r: 255, g: 0, b: 255});\n * @param str text color to apply 24bit rgb to\n * @param color code\n */\nexport function rgb24(str: string, color: number | Rgb): string {\n  if (typeof color === \"number\") {\n    return run(\n      str,\n      code(\n        [38, 2, (color >> 16) & 0xff, (color >> 8) & 0xff, color & 0xff],\n        39,\n      ),\n    );\n  }\n  return run(\n    str,\n    code(\n      [\n        38,\n        2,\n        clampAndTruncate(color.r),\n        clampAndTruncate(color.g),\n        clampAndTruncate(color.b),\n      ],\n      39,\n    ),\n  );\n}\n\n/**\n * Set background color using 24bit rgb.\n * `color` can be a number in range `0x000000` to `0xffffff` or\n * an `Rgb`.\n *\n * To produce the color magenta:\n *\n *      bgRgb24(\"foo\", 0xff00ff);\n *      bgRgb24(\"foo\", {r: 255, g: 0, b: 255});\n * @param str text color to apply 24bit rgb to\n * @param color code\n */\nexport function bgRgb24(str: string, color: number | Rgb): string {\n  if (typeof color === \"number\") {\n    return run(\n      str,\n      code(\n        [48, 2, (color >> 16) & 0xff, (color >> 8) & 0xff, color & 0xff],\n        49,\n      ),\n    );\n  }\n  return run(\n    str,\n    code(\n      [\n        48,\n        2,\n        clampAndTruncate(color.r),\n        clampAndTruncate(color.g),\n        clampAndTruncate(color.b),\n      ],\n      49,\n    ),\n  );\n}\n\n// https://github.com/chalk/ansi-regex/blob/2b56fb0c7a07108e5b54241e8faec160d393aedb/index.js\nconst ANSI_PATTERN = new RegExp(\n  [\n    \"[\\\\u001B\\\\u009B][[\\\\]()#;?]*(?:(?:(?:[a-zA-Z\\\\d]*(?:;[-a-zA-Z\\\\d\\\\/#&.:=?%@~_]*)*)?\\\\u0007)\",\n    \"(?:(?:\\\\d{1,4}(?:;\\\\d{0,4})*)?[\\\\dA-PR-TZcf-ntqry=><~]))\",\n  ].join(\"|\"),\n  \"g\",\n);\n\n/**\n * Remove ANSI escape codes from the string.\n * @param string to remove ANSI escape codes from\n */\nexport function stripColor(string: string): string {\n  return string.replace(ANSI_PATTERN, \"\");\n}\n"],"names":[],"mappings":"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"} \ No newline at end of file diff --git "a/.\\.cache/gen/https/deno.land/c3031fe6d1ec46c7ee6519cd64b11875eca3b83ce3ceb1323a43a0810846f180.meta" "b/.\\.cache/gen/https/deno.land/c3031fe6d1ec46c7ee6519cd64b11875eca3b83ce3ceb1323a43a0810846f180.meta" deleted file mode 100644 index 5f7523a..0000000 --- "a/.\\.cache/gen/https/deno.land/c3031fe6d1ec46c7ee6519cd64b11875eca3b83ce3ceb1323a43a0810846f180.meta" +++ /dev/null @@ -1 +0,0 @@ -{"source_hash":"6994463079202639405","emit_hash":"5311910704850736559"} \ No newline at end of file diff --git a/README.md b/README.md index b8d330e..00eab21 100644 --- a/README.md +++ b/README.md @@ -32,7 +32,7 @@ By default, this makes the blockchain the best place to keep deeds. - Basic Checks before listing and unlisting data. - Error Handling and checking to make sure information is posted and rooms cannot be zero -![Code_Screenshot](https://i.imgur.com/vQjHhOB.png) +![Code_Screenshot](https://i.imgur.com/xcWAHWr.png) ## 👨‍🔧 Project Plan diff --git a/contracts/deed.clar b/contracts/deed.clar index 11780c9..d058a2b 100644 --- a/contracts/deed.clar +++ b/contracts/deed.clar @@ -110,12 +110,13 @@ (define-public (buy-deed (deed-id uint)) (let ( - (listed (unwrap! (get listed (map-get? deeds deed-id)) err-deed-does-not-exist)) + (owner (unwrap! (get owner (map-get? deeds deed-id)) err-deed-does-not-exist)) + (listed (unwrap-panic (get listed (map-get? deeds deed-id)))) (price (unwrap-panic (get price (map-get? deeds deed-id)))) ) (asserts! listed err-deed-not-listed) (asserts! (is-eq (> price u0)) err-price-expected-more) - (try! (stx-transfer? price tx-sender (as-contract tx-sender))) ;; Do the transaction + (try! (stx-transfer? price tx-sender owner)) ;; Transaction from the buyer to the owner (map-set deeds deed-id (merge (unwrap-panic (map-get? deeds deed-id)) {owner: tx-sender, listed: false})) (ok true) ) @@ -228,3 +229,10 @@ ) ) ) + +;;* Gets the owner of a deed +;; @param deed-id The Deed ID +;; @returns principal The Owner address of the Deed +(define-read-only (get-owner (deed-id uint)) + (ok (unwrap! (get owner (map-get? deeds deed-id)) err-deed-does-not-exist)) +) diff --git a/tests/deed_test.ts b/tests/deed_test.ts index 5c4b9da..daef270 100644 --- a/tests/deed_test.ts +++ b/tests/deed_test.ts @@ -7,9 +7,9 @@ import { } from "https://deno.land/x/clarinet@v1.0.2/index.ts"; import { assertEquals } from "https://deno.land/std@0.90.0/testing/asserts.ts"; -// Clarinet Default Test +//* Clarinet Default Test Clarinet.test({ - name: "Ensure that <...>", + name: "Ensure that contract works", async fn(chain: Chain, accounts: Map) { let block = chain.mineBlock([ /* @@ -32,7 +32,7 @@ Clarinet.test({ }); //* Stats to Run the test -const contractname = "deed"; +const contractName = "deed"; const defaultStxVaultAmount = 5000; const defaultMembers = [ @@ -42,3 +42,462 @@ const defaultMembers = [ "wallet_3", "wallet_4", ]; + +/* +- Error List - + +err u100 - Deed is not listed for sale +err u101 - Deed is listed for sale +err u102 - Deed does not exist +err u103 - Deed already exists +err u104 - Invalid Value in a Tuple +err u105 - Not the Deed Owner +err u106 - Price is zero or not enough +*/ + +//* Accessing all the functions using the Deed ID #1 +Clarinet.test({ + name: "Cannot access any function without creating a deed", + async fn(chain: Chain, accounts: Map) { + let deployer = accounts.get("deployer")!; + let wallet1 = accounts.get("wallet_1")!; + + let block = chain.mineBlock([ + // Transfer Deed + Tx.contractCall( + contractName, + "transfer-deed", + [types.principal(wallet1.address), types.uint(1)], + deployer.address + ), + // Listing for sale + Tx.contractCall( + contractName, + "list-for-sale", + [types.uint(1), types.uint(100)], + deployer.address + ), + // Unlisting from sale + Tx.contractCall( + contractName, + "unlist-for-sale", + [types.uint(1)], + deployer.address + ), + // Buy Deed + Tx.contractCall( + contractName, + "buy-deed", + [types.uint(1)], + deployer.address + ), + // Change Price + Tx.contractCall( + contractName, + "change-price", + [types.uint(1), types.uint(500)], + deployer.address + ), + // Change Images + Tx.contractCall( + contractName, + "change-images", + [types.uint(1), types.ascii("Test")], + deployer.address + ), + // Change Name + Tx.contractCall( + contractName, + "change-name", + [types.uint(1), types.ascii("Test")], + deployer.address + ), + // Change Bedroom + Tx.contractCall( + contractName, + "change-bedroom", + [types.uint(1), types.uint(4)], + deployer.address + ), + // Change Bathroom + Tx.contractCall( + contractName, + "change-bathroom", + [types.uint(1), types.uint(4)], + deployer.address + ), + // Change Size + Tx.contractCall( + contractName, + "change-size", + [types.uint(1), types.uint(200), types.uint(200)], + deployer.address + ), + // Get Deed + Tx.contractCall( + contractName, + "get-deed", + [types.uint(1)], + deployer.address + ), + ]); + + // Transfer Should Fail + block.receipts[0].result.expectErr().expectUint(102); + // Listing should fail + block.receipts[1].result.expectErr().expectUint(102); + // Unlist should fail + block.receipts[2].result.expectErr().expectUint(102); + // Buy Deed should fail + block.receipts[3].result.expectErr().expectUint(102); + // Changing Price should fail + block.receipts[4].result.expectErr().expectUint(102); + // Changing Images should fail + block.receipts[5].result.expectErr().expectUint(102); + // Changing Name should fail + block.receipts[6].result.expectErr().expectUint(102); + // Changing Bedroom should fail + block.receipts[7].result.expectErr().expectUint(102); + // Changing Bathroom should fail + block.receipts[8].result.expectErr().expectUint(102); + // Changing Size + block.receipts[9].result.expectErr().expectUint(102); + // Getting Deed + block.receipts[10].result.expectErr().expectUint(102); + }, +}); + +//* Creating a Deed starting from incorrect values +Clarinet.test({ + name: "Creating a Deed starting from incorrect values", + async fn(chain: Chain, accounts: Map) { + let deployer = accounts.get("deployer")!; + + let block = chain.mineBlock([ + // Create a Deeds Incorrectly + Tx.contractCall( + contractName, + "create-deed", + [ + types.ascii(""), // Name + types.ascii(""), // Image URL + types.uint(0), // Bedroom + types.uint(0), // Bathroom + types.uint(0), // Size X + types.uint(0), // Size Y + ], + deployer.address + ), + Tx.contractCall( + contractName, + "create-deed", + [ + types.ascii("Name"), // Name + types.ascii(""), // Image URL + types.uint(0), // Bedroom + types.uint(0), // Bathroom + types.uint(0), // Size X + types.uint(0), // Size Y + ], + deployer.address + ), + Tx.contractCall( + contractName, + "create-deed", + [ + types.ascii("Name"), // Name + types.ascii("URL"), // Image URL + types.uint(0), // Bedroom + types.uint(0), // Bathroom + types.uint(0), // Size X + types.uint(0), // Size Y + ], + deployer.address + ), + Tx.contractCall( + contractName, + "create-deed", + [ + types.ascii("Name"), // Name + types.ascii("URL"), // Image URL + types.uint(1), // Bedroom + types.uint(0), // Bathroom + types.uint(0), // Size X + types.uint(0), // Size Y + ], + deployer.address + ), + Tx.contractCall( + contractName, + "create-deed", + [ + types.ascii("Name"), // Name + types.ascii("URL"), // Image URL + types.uint(1), // Bedroom + types.uint(2), // Bathroom + types.uint(0), // Size X + types.uint(0), // Size Y + ], + deployer.address + ), + Tx.contractCall( + contractName, + "create-deed", + [ + types.ascii("Name"), // Name + types.ascii("URL"), // Image URL + types.uint(1), // Bedroom + types.uint(2), // Bathroom + types.uint(500), // Size X + types.uint(0), // Size Y + ], + deployer.address + ), + // Valid Transaction + Tx.contractCall( + contractName, + "create-deed", + [ + types.ascii("Name"), // Name + types.ascii("URL"), // Image URL + types.uint(1), // Bedroom + types.uint(2), // Bathroom + types.uint(500), // Size X + types.uint(500), // Size Y + ], + deployer.address + ), + ]); + + // Incorrect Ones + block.receipts[0].result.expectErr().expectUint(104); + block.receipts[1].result.expectErr().expectUint(104); + block.receipts[2].result.expectErr().expectUint(104); + block.receipts[3].result.expectErr().expectUint(104); + block.receipts[4].result.expectErr().expectUint(104); + block.receipts[5].result.expectErr().expectUint(104); + + // Correct one + block.receipts[6].result.expectOk(); + }, +}); + +//* Creating a Deed and changing information +Clarinet.test({ + name: "Creating a Deed and changing information", + async fn(chain: Chain, accounts: Map) { + let deployer = accounts.get("deployer")!; + + let block = chain.mineBlock([ + // Valid Transaction + Tx.contractCall( + contractName, + "create-deed", + [ + types.ascii("Name"), // Name + types.ascii("URL"), // Image URL + types.uint(1), // Bedroom + types.uint(2), // Bathroom + types.uint(500), // Size X + types.uint(500), // Size Y + ], + deployer.address + ), + Tx.contractCall( + contractName, + "get-deed", + [types.uint(1)], + deployer.address + ), + // Changing Price + Tx.contractCall( + contractName, + "change-price", + [types.uint(1), types.uint(500)], + deployer.address + ), + // Changing Images URL + Tx.contractCall( + contractName, + "change-images", + [types.uint(1), types.ascii("https://google.com")], + deployer.address + ), + // Changing Images URL + Tx.contractCall( + contractName, + "change-name", + [types.uint(1), types.ascii("Jake")], + deployer.address + ), + // Changing Bedroom Count + Tx.contractCall( + contractName, + "change-bedroom", + [types.uint(1), types.uint(4)], + deployer.address + ), + Tx.contractCall( + contractName, + "change-bathroom", + [types.uint(1), types.uint(2)], + deployer.address + ), + Tx.contractCall( + contractName, + "change-size", + [types.uint(1), types.uint(200), types.uint(200)], + deployer.address + ), + ]); + + // Created Deed + block.receipts[0].result.expectOk(); + // Getting Deed by ID + block.receipts[1].result.expectOk().expectTuple(); + // Changing Price + block.receipts[2].result.expectOk(); + // Changing Image URL + block.receipts[3].result.expectOk(); + // Changing Name + block.receipts[4].result.expectOk(); + // Changing Bedroom count + block.receipts[5].result.expectOk(); + // Changing Bathroom count + block.receipts[6].result.expectOk(); + // Changing Size + block.receipts[7].result.expectOk(); + }, +}); + +//* Listing a Deed and Selling it +Clarinet.test({ + name: "Listing a Deed and selling it", + async fn(chain: Chain, accounts: Map) { + let deployer = accounts.get("deployer")!; + let buyer = accounts.get("wallet_1")!; + + let block = chain.mineBlock([ + // Valid Transaction + Tx.contractCall( + contractName, + "create-deed", + [ + types.ascii("House"), // Name + types.ascii("https://google.com"), // Image URL + types.uint(1), // Bedroom + types.uint(2), // Bathroom + types.uint(500), // Size X + types.uint(500), // Size Y + ], + deployer.address + ), + // Listing House for Sale + Tx.contractCall( + contractName, + "list-for-sale", + [ + types.uint(1), // ID + types.uint(1200), // Price + ], + deployer.address + ), + Tx.contractCall( + contractName, + "get-owner", + [ + types.uint(1), // ID + ], + deployer.address + ), + // Buying Deed + Tx.contractCall(contractName, "buy-deed", [types.uint(1)], buyer.address), + Tx.contractCall( + contractName, + "get-owner", + [ + types.uint(1), // ID + ], + deployer.address + ), + ]); + + // Created Deed + block.receipts[0].result.expectOk(); + // Listing Deed + block.receipts[1].result.expectOk(); + // Checking Address before transfer + block.receipts[2].result.expectOk().expectPrincipal(deployer.address); + // Buying Deed + block.receipts[3].events.expectSTXTransferEvent( + 1200, + buyer.address, + deployer.address + ); + // Confirming Address after transfer + block.receipts[4].result.expectOk().expectPrincipal(buyer.address); + }, +}); + +//* Trying to change information on an unowned deed + +//* Transferring Deed +Clarinet.test({ + name: "Transfer Deed", + async fn(chain: Chain, accounts: Map) { + let deployer = accounts.get("deployer")!; + let buyer = accounts.get("wallet_1")!; + + let block = chain.mineBlock([ + // Valid Transaction + Tx.contractCall( + contractName, + "create-deed", + [ + types.ascii("House"), // Name + types.ascii("https://google.com"), // Image URL + types.uint(1), // Bedroom + types.uint(2), // Bathroom + types.uint(500), // Size X + types.uint(500), // Size Y + ], + deployer.address + ), + Tx.contractCall( + contractName, + "get-owner", + [ + types.uint(1), // ID + ], + deployer.address + ), + // Transfer Deed + Tx.contractCall( + contractName, + "transfer-deed", + [ + types.principal(buyer.address), // Transfer Account + types.uint(1), // ID + ], + deployer.address + ), + Tx.contractCall( + contractName, + "get-owner", + [ + types.uint(1), // ID + ], + deployer.address + ), + ]); + + // Created Deed + block.receipts[0].result.expectOk(); + // Checking the Owner before transfer + block.receipts[1].result.expectOk().expectPrincipal(deployer.address); + // Transferred Ownership + block.receipts[2].result.expectOk(); + // Checking the Owner after transfer + block.receipts[3].result.expectOk().expectPrincipal(buyer.address); + }, +});