ic-mops 1.11.1 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.DS_Store +0 -0
- package/.eslintrc.json +7 -7
- package/CHANGELOG.md +15 -0
- package/api/actors.ts +41 -37
- package/api/downloadPackageFiles.ts +75 -61
- package/api/getHighestVersion.ts +5 -5
- package/api/index.ts +4 -4
- package/api/network.ts +19 -21
- package/api/resolveVersion.ts +14 -11
- package/bin/mops.js +1 -1
- package/bun.lock +234 -198
- package/bundle/bench/bench-canister.mo +2 -2
- package/bundle/bench/user-bench.mo +0 -4
- package/bundle/bin/mops.js +1 -1
- package/bundle/cli.js +1000 -924
- package/bundle/cli.tgz +0 -0
- package/bundle/declarations/bench/bench.did +3 -3
- package/bundle/declarations/bench/bench.did.d.ts +3 -3
- package/bundle/declarations/bench/index.d.ts +3 -3
- package/bundle/declarations/bench/index.js +1 -1
- package/bundle/declarations/main/index.d.ts +3 -3
- package/bundle/declarations/main/index.js +1 -1
- package/bundle/declarations/main/main.did +78 -121
- package/bundle/declarations/main/main.did.d.ts +48 -98
- package/bundle/declarations/main/main.did.js +53 -107
- package/bundle/declarations/storage/index.d.ts +3 -3
- package/bundle/declarations/storage/index.js +4 -4
- package/bundle/declarations/storage/storage.did.d.ts +3 -3
- package/bundle/package.json +6 -5
- package/bundle/templates/mops-publish.yml +3 -3
- package/bundle/templates/mops-test.yml +3 -3
- package/bundle-package-json.ts +8 -8
- package/cache.ts +80 -65
- package/check-requirements.ts +49 -45
- package/cli.ts +577 -376
- package/commands/add.ts +142 -129
- package/commands/available-updates.ts +55 -28
- package/commands/bench/bench-canister.mo +114 -108
- package/commands/bench/user-bench.mo +6 -6
- package/commands/bench-replica.ts +146 -106
- package/commands/bench.ts +563 -497
- package/commands/build.ts +177 -0
- package/commands/bump.ts +68 -57
- package/commands/check-candid.ts +24 -0
- package/commands/docs-coverage.ts +124 -102
- package/commands/docs.ts +118 -108
- package/commands/format.ts +171 -155
- package/commands/init.ts +301 -275
- package/commands/install/install-all.ts +75 -62
- package/commands/install/install-dep.ts +43 -28
- package/commands/install/install-deps.ts +23 -15
- package/commands/install/install-local-dep.ts +42 -34
- package/commands/install/install-mops-dep.ts +154 -123
- package/commands/install/sync-local-cache.ts +39 -35
- package/commands/maintainer.ts +109 -99
- package/commands/outdated.ts +31 -18
- package/commands/owner.ts +107 -99
- package/commands/publish.ts +534 -443
- package/commands/remove.ts +119 -89
- package/commands/replica.ts +391 -303
- package/commands/search.ts +42 -36
- package/commands/self.ts +63 -56
- package/commands/sources.ts +66 -49
- package/commands/sync.ts +92 -75
- package/commands/template.ts +145 -102
- package/commands/test/mmf1.ts +146 -119
- package/commands/test/reporters/compact-reporter.ts +87 -84
- package/commands/test/reporters/files-reporter.ts +56 -51
- package/commands/test/reporters/reporter.ts +12 -6
- package/commands/test/reporters/silent-reporter.ts +58 -59
- package/commands/test/reporters/verbose-reporter.ts +66 -54
- package/commands/test/test.ts +497 -460
- package/commands/test/utils.ts +85 -6
- package/commands/toolchain/index.ts +363 -322
- package/commands/toolchain/moc.ts +78 -50
- package/commands/toolchain/pocket-ic.ts +41 -34
- package/commands/toolchain/toolchain-utils.ts +92 -72
- package/commands/toolchain/wasmtime.ts +37 -34
- package/commands/update.ts +91 -56
- package/commands/user.ts +90 -81
- package/commands/watch/deployer.ts +188 -152
- package/commands/watch/error-checker.ts +90 -80
- package/commands/watch/formatter.ts +72 -60
- package/commands/watch/generator.ts +116 -96
- package/commands/watch/globMoFiles.ts +13 -13
- package/commands/watch/parseDfxJson.ts +63 -57
- package/commands/watch/tester.ts +83 -65
- package/commands/watch/warning-checker.ts +149 -136
- package/commands/watch/watch.ts +123 -95
- package/declarations/bench/bench.did.d.ts +3 -3
- package/declarations/bench/index.d.ts +3 -3
- package/declarations/bench/index.js +1 -1
- package/declarations/main/index.d.ts +3 -3
- package/declarations/main/index.js +1 -1
- package/declarations/main/main.did.d.ts +3 -3
- package/declarations/storage/index.d.ts +3 -3
- package/declarations/storage/index.js +4 -4
- package/declarations/storage/storage.did.d.ts +3 -3
- package/dist/api/actors.d.ts +4 -4
- package/dist/api/actors.js +8 -8
- package/dist/api/downloadPackageFiles.d.ts +2 -2
- package/dist/api/downloadPackageFiles.js +10 -10
- package/dist/api/getHighestVersion.js +1 -1
- package/dist/api/index.d.ts +4 -4
- package/dist/api/index.js +4 -4
- package/dist/api/network.js +9 -9
- package/dist/api/resolveVersion.js +3 -3
- package/dist/bin/mops.js +1 -1
- package/dist/bundle-package-json.js +8 -8
- package/dist/cache.js +22 -17
- package/dist/check-requirements.js +11 -11
- package/dist/cli.js +283 -186
- package/dist/commands/add.d.ts +1 -1
- package/dist/commands/add.js +41 -38
- package/dist/commands/available-updates.d.ts +1 -1
- package/dist/commands/available-updates.js +32 -14
- package/dist/commands/bench/bench-canister.mo +114 -108
- package/dist/commands/bench/user-bench.mo +6 -6
- package/dist/commands/bench-replica.d.ts +6 -5
- package/dist/commands/bench-replica.js +58 -36
- package/dist/commands/bench.d.ts +5 -5
- package/dist/commands/bench.js +134 -118
- package/dist/commands/build.d.ts +7 -0
- package/dist/commands/build.js +121 -0
- package/dist/commands/bump.js +27 -18
- package/dist/commands/check-candid.d.ts +4 -0
- package/dist/commands/check-candid.js +15 -0
- package/dist/commands/docs-coverage.d.ts +1 -1
- package/dist/commands/docs-coverage.js +45 -31
- package/dist/commands/docs.d.ts +1 -1
- package/dist/commands/docs.js +39 -38
- package/dist/commands/format.js +31 -27
- package/dist/commands/init.js +102 -92
- package/dist/commands/install/install-all.d.ts +2 -2
- package/dist/commands/install/install-all.js +23 -21
- package/dist/commands/install/install-dep.d.ts +1 -1
- package/dist/commands/install/install-dep.js +21 -8
- package/dist/commands/install/install-deps.d.ts +1 -1
- package/dist/commands/install/install-deps.js +1 -1
- package/dist/commands/install/install-local-dep.js +11 -9
- package/dist/commands/install/install-mops-dep.d.ts +1 -1
- package/dist/commands/install/install-mops-dep.js +32 -27
- package/dist/commands/install/sync-local-cache.js +10 -10
- package/dist/commands/maintainer.js +21 -21
- package/dist/commands/outdated.js +16 -6
- package/dist/commands/owner.js +21 -21
- package/dist/commands/publish.js +148 -128
- package/dist/commands/remove.d.ts +1 -1
- package/dist/commands/remove.js +42 -30
- package/dist/commands/replica.d.ts +9 -8
- package/dist/commands/replica.js +105 -65
- package/dist/commands/search.js +15 -13
- package/dist/commands/self.js +31 -28
- package/dist/commands/sources.d.ts +5 -1
- package/dist/commands/sources.js +23 -17
- package/dist/commands/sync.d.ts +1 -1
- package/dist/commands/sync.js +38 -25
- package/dist/commands/template.js +66 -56
- package/dist/commands/test/mmf1.d.ts +3 -3
- package/dist/commands/test/mmf1.js +33 -31
- package/dist/commands/test/reporters/compact-reporter.d.ts +3 -3
- package/dist/commands/test/reporters/compact-reporter.js +19 -15
- package/dist/commands/test/reporters/files-reporter.d.ts +3 -3
- package/dist/commands/test/reporters/files-reporter.js +18 -14
- package/dist/commands/test/reporters/reporter.d.ts +2 -2
- package/dist/commands/test/reporters/silent-reporter.d.ts +3 -3
- package/dist/commands/test/reporters/silent-reporter.js +4 -4
- package/dist/commands/test/reporters/verbose-reporter.d.ts +3 -3
- package/dist/commands/test/reporters/verbose-reporter.js +17 -13
- package/dist/commands/test/test.d.ts +4 -4
- package/dist/commands/test/test.js +151 -181
- package/dist/commands/test/utils.d.ts +6 -0
- package/dist/commands/test/utils.js +63 -2
- package/dist/commands/toolchain/index.d.ts +1 -1
- package/dist/commands/toolchain/index.js +81 -69
- package/dist/commands/toolchain/moc.d.ts +1 -1
- package/dist/commands/toolchain/moc.js +48 -24
- package/dist/commands/toolchain/pocket-ic.js +12 -12
- package/dist/commands/toolchain/toolchain-utils.d.ts +2 -0
- package/dist/commands/toolchain/toolchain-utils.js +32 -23
- package/dist/commands/toolchain/wasmtime.js +11 -11
- package/dist/commands/update.d.ts +1 -1
- package/dist/commands/update.js +30 -12
- package/dist/commands/user.js +31 -28
- package/dist/commands/watch/deployer.d.ts +4 -4
- package/dist/commands/watch/deployer.js +45 -36
- package/dist/commands/watch/error-checker.d.ts +2 -2
- package/dist/commands/watch/error-checker.js +27 -27
- package/dist/commands/watch/formatter.d.ts +4 -4
- package/dist/commands/watch/formatter.js +17 -17
- package/dist/commands/watch/generator.d.ts +3 -3
- package/dist/commands/watch/generator.js +28 -23
- package/dist/commands/watch/globMoFiles.js +8 -8
- package/dist/commands/watch/parseDfxJson.d.ts +2 -2
- package/dist/commands/watch/parseDfxJson.js +9 -9
- package/dist/commands/watch/tester.d.ts +4 -4
- package/dist/commands/watch/tester.js +23 -21
- package/dist/commands/watch/warning-checker.d.ts +3 -3
- package/dist/commands/watch/warning-checker.js +36 -36
- package/dist/commands/watch/watch.js +45 -32
- package/dist/declarations/bench/bench.did.d.ts +3 -3
- package/dist/declarations/bench/index.d.ts +3 -3
- package/dist/declarations/bench/index.js +1 -1
- package/dist/declarations/main/index.d.ts +3 -3
- package/dist/declarations/main/index.js +1 -1
- package/dist/declarations/main/main.did.d.ts +3 -3
- package/dist/declarations/storage/index.d.ts +3 -3
- package/dist/declarations/storage/index.js +4 -4
- package/dist/declarations/storage/storage.did.d.ts +3 -3
- package/dist/environments/nodejs/cli.d.ts +1 -0
- package/dist/environments/nodejs/cli.js +4 -0
- package/dist/environments/web/cli.d.ts +1 -0
- package/dist/environments/web/cli.js +4 -0
- package/dist/error.d.ts +1 -0
- package/dist/error.js +5 -0
- package/dist/fix-dist.js +5 -5
- package/dist/helpers/find-changelog-entry.js +8 -5
- package/dist/helpers/get-dep-name.d.ts +1 -0
- package/dist/helpers/get-dep-name.js +4 -1
- package/dist/helpers/get-dfx-version.js +4 -4
- package/dist/helpers/get-moc-path.js +8 -7
- package/dist/helpers/get-moc-version.js +10 -7
- package/dist/helpers/get-package-id.js +2 -2
- package/dist/helpers/is-candid-compatible.d.ts +1 -0
- package/dist/helpers/is-candid-compatible.js +20 -0
- package/dist/integrity.d.ts +1 -1
- package/dist/integrity.js +47 -38
- package/dist/jest.config.d.ts +11 -0
- package/dist/jest.config.js +14 -0
- package/dist/mops.d.ts +6 -6
- package/dist/mops.js +87 -80
- package/dist/notify-installs.js +4 -4
- package/dist/package.json +11 -10
- package/dist/pem.d.ts +3 -3
- package/dist/pem.js +20 -12
- package/dist/release-cli.js +20 -20
- package/dist/resolve-packages.d.ts +1 -1
- package/dist/resolve-packages.js +52 -36
- package/dist/templates/mops-publish.yml +3 -3
- package/dist/templates/mops-test.yml +3 -3
- package/dist/templates/src/lib.mo +13 -13
- package/dist/templates/test/lib.test.mo +2 -2
- package/dist/templates.js +1 -1
- package/dist/tests/cli.test.d.ts +1 -0
- package/dist/tests/cli.test.js +63 -0
- package/dist/types.d.ts +14 -4
- package/dist/vessel.d.ts +2 -2
- package/dist/vessel.js +41 -34
- package/dist/wasm/pkg/bundler/package.json +20 -0
- package/dist/wasm/pkg/bundler/wasm.d.ts +3 -0
- package/dist/wasm/pkg/bundler/wasm.js +5 -0
- package/dist/wasm/pkg/bundler/wasm_bg.js +93 -0
- package/dist/wasm/pkg/bundler/wasm_bg.wasm +0 -0
- package/dist/wasm/pkg/bundler/wasm_bg.wasm.d.ts +8 -0
- package/dist/wasm/pkg/nodejs/package.json +14 -0
- package/dist/wasm/pkg/nodejs/wasm.d.ts +3 -0
- package/dist/wasm/pkg/nodejs/wasm.js +98 -0
- package/dist/wasm/pkg/nodejs/wasm_bg.wasm +0 -0
- package/dist/wasm/pkg/nodejs/wasm_bg.wasm.d.ts +8 -0
- package/dist/wasm/pkg/web/package.json +18 -0
- package/dist/wasm/pkg/web/wasm.d.ts +35 -0
- package/dist/wasm/pkg/web/wasm.js +191 -0
- package/dist/wasm/pkg/web/wasm_bg.wasm +0 -0
- package/dist/wasm/pkg/web/wasm_bg.wasm.d.ts +8 -0
- package/dist/wasm.d.ts +5 -0
- package/dist/wasm.js +10 -0
- package/environments/nodejs/cli.ts +6 -0
- package/environments/web/cli.ts +6 -0
- package/error.ts +6 -0
- package/fix-dist.ts +5 -5
- package/global.d.ts +3 -3
- package/helpers/find-changelog-entry.ts +26 -23
- package/helpers/get-dep-name.ts +7 -3
- package/helpers/get-dfx-version.ts +8 -9
- package/helpers/get-moc-path.ts +25 -26
- package/helpers/get-moc-version.ts +21 -19
- package/helpers/get-package-id.ts +4 -4
- package/helpers/is-candid-compatible.ts +22 -0
- package/integrity.ts +270 -236
- package/jest.config.js +14 -0
- package/mops.ts +238 -215
- package/notify-installs.ts +16 -17
- package/package.json +21 -15
- package/parallel.ts +28 -24
- package/pem.ts +55 -47
- package/release-cli.ts +73 -39
- package/resolve-packages.ts +231 -189
- package/templates/mops-publish.yml +3 -3
- package/templates/mops-test.yml +3 -3
- package/templates/src/lib.mo +13 -13
- package/templates/test/lib.test.mo +2 -2
- package/templates.ts +4 -4
- package/tests/__snapshots__/cli.test.ts.snap +202 -0
- package/tests/build/error/candid/bar.did +3 -0
- package/tests/build/error/dfx.json +12 -0
- package/tests/build/error/mops.toml +9 -0
- package/tests/build/error/src/Bar.mo +5 -0
- package/tests/build/error/src/Foo.mo +5 -0
- package/tests/build/success/.dfx/local/canister_ids.json +17 -0
- package/tests/build/success/.dfx/local/canisters/bar/bar.did +3 -0
- package/tests/build/success/.dfx/local/canisters/bar/bar.most +4 -0
- package/tests/build/success/.dfx/local/canisters/bar/bar.wasm +0 -0
- package/tests/build/success/.dfx/local/canisters/bar/constructor.did +3 -0
- package/tests/build/success/.dfx/local/canisters/bar/index.js +42 -0
- package/tests/build/success/.dfx/local/canisters/bar/init_args.txt +1 -0
- package/tests/build/success/.dfx/local/canisters/bar/service.did +3 -0
- package/tests/build/success/.dfx/local/canisters/bar/service.did.d.ts +7 -0
- package/tests/build/success/.dfx/local/canisters/bar/service.did.js +4 -0
- package/tests/build/success/.dfx/local/canisters/foo/constructor.did +3 -0
- package/tests/build/success/.dfx/local/canisters/foo/foo.did +3 -0
- package/tests/build/success/.dfx/local/canisters/foo/foo.most +4 -0
- package/tests/build/success/.dfx/local/canisters/foo/foo.wasm +0 -0
- package/tests/build/success/.dfx/local/canisters/foo/index.js +42 -0
- package/tests/build/success/.dfx/local/canisters/foo/init_args.txt +1 -0
- package/tests/build/success/.dfx/local/canisters/foo/service.did +3 -0
- package/tests/build/success/.dfx/local/canisters/foo/service.did.d.ts +7 -0
- package/tests/build/success/.dfx/local/canisters/foo/service.did.js +4 -0
- package/tests/build/success/.dfx/local/lsp/ucwa4-rx777-77774-qaada-cai.did +3 -0
- package/tests/build/success/.dfx/local/lsp/ulvla-h7777-77774-qaacq-cai.did +3 -0
- package/tests/build/success/.dfx/local/network-id +4 -0
- package/tests/build/success/candid/bar.did +3 -0
- package/tests/build/success/dfx.json +12 -0
- package/tests/build/success/mops.toml +9 -0
- package/tests/build/success/src/Bar.mo +5 -0
- package/tests/build/success/src/Foo.mo +5 -0
- package/tests/check-candid/a.did +3 -0
- package/tests/check-candid/b.did +5 -0
- package/tests/check-candid/c.did +3 -0
- package/tests/cli.test.ts +82 -0
- package/tsconfig.json +26 -19
- package/types.ts +41 -31
- package/vessel.ts +219 -187
- package/wasm/Cargo.lock +1475 -0
- package/wasm/Cargo.toml +28 -0
- package/wasm/pkg/bundler/package.json +20 -0
- package/wasm/pkg/bundler/wasm.d.ts +3 -0
- package/wasm/pkg/bundler/wasm.js +5 -0
- package/wasm/pkg/bundler/wasm_bg.js +93 -0
- package/wasm/pkg/bundler/wasm_bg.wasm +0 -0
- package/wasm/pkg/bundler/wasm_bg.wasm.d.ts +8 -0
- package/wasm/pkg/nodejs/package.json +14 -0
- package/wasm/pkg/nodejs/wasm.d.ts +3 -0
- package/wasm/pkg/nodejs/wasm.js +98 -0
- package/wasm/pkg/nodejs/wasm_bg.wasm +0 -0
- package/wasm/pkg/nodejs/wasm_bg.wasm.d.ts +8 -0
- package/wasm/pkg/web/package.json +18 -0
- package/wasm/pkg/web/wasm.d.ts +35 -0
- package/wasm/pkg/web/wasm.js +191 -0
- package/wasm/pkg/web/wasm_bg.wasm +0 -0
- package/wasm/pkg/web/wasm_bg.wasm.d.ts +8 -0
- package/wasm/src/lib.rs +17 -0
- package/wasm.ts +16 -0
package/commands/template.ts
CHANGED
|
@@ -1,109 +1,152 @@
|
|
|
1
|
-
import fs from
|
|
2
|
-
import path from
|
|
3
|
-
import chalk from
|
|
4
|
-
import prompts from
|
|
5
|
-
import {kebabCase, pascalCase} from
|
|
6
|
-
import {getRootDir, readConfig} from
|
|
7
|
-
import {copyTemplateFileSync} from
|
|
1
|
+
import fs from "node:fs";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import chalk from "chalk";
|
|
4
|
+
import prompts from "prompts";
|
|
5
|
+
import { kebabCase, pascalCase } from "change-case";
|
|
6
|
+
import { getRootDir, readConfig } from "../mops.js";
|
|
7
|
+
import { copyTemplateFileSync } from "../templates.js";
|
|
8
8
|
|
|
9
|
-
export async function template(templateName
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
9
|
+
export async function template(templateName?: string, options: any = {}) {
|
|
10
|
+
if (!templateName) {
|
|
11
|
+
let res = await prompts({
|
|
12
|
+
type: "select",
|
|
13
|
+
name: "value",
|
|
14
|
+
message: "Select template:",
|
|
15
|
+
choices: [
|
|
16
|
+
{ title: "README.md", value: "readme" },
|
|
17
|
+
{ title: "src/lib.mo", value: "lib.mo" },
|
|
18
|
+
{ title: "test/lib.test.mo", value: "lib.test.mo" },
|
|
19
|
+
{ title: "License MIT", value: "license:MIT" },
|
|
20
|
+
{ title: "License Apache-2.0", value: "license:Apache-2.0" },
|
|
21
|
+
{
|
|
22
|
+
title: "GitHub Workflow to run 'mops test'",
|
|
23
|
+
value: "github-workflow:mops-test",
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
title: "GitHub Workflow to publish a package",
|
|
27
|
+
value: "github-workflow:mops-publish",
|
|
28
|
+
},
|
|
29
|
+
{ title: "× Cancel", value: "" },
|
|
30
|
+
],
|
|
31
|
+
initial: 0,
|
|
32
|
+
});
|
|
33
|
+
templateName = res.value;
|
|
34
|
+
}
|
|
29
35
|
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
36
|
+
if (templateName === "github-workflow:mops-test") {
|
|
37
|
+
let dest = path.resolve(getRootDir(), ".github/workflows/mops-test.yml");
|
|
38
|
+
if (fs.existsSync(dest)) {
|
|
39
|
+
console.log(
|
|
40
|
+
chalk.yellow("Workflow already exists:"),
|
|
41
|
+
path.relative(getRootDir(), dest),
|
|
42
|
+
);
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
fs.mkdirSync(path.resolve(getRootDir(), ".github/workflows"), {
|
|
46
|
+
recursive: true,
|
|
47
|
+
});
|
|
48
|
+
copyTemplateFileSync("mops-test.yml", dest);
|
|
49
|
+
console.log(chalk.green("Created"), path.relative(getRootDir(), dest));
|
|
50
|
+
} else if (templateName === "github-workflow:mops-publish") {
|
|
51
|
+
let dest = path.resolve(getRootDir(), ".github/workflows/mops-publish.yml");
|
|
52
|
+
if (fs.existsSync(dest)) {
|
|
53
|
+
console.log(
|
|
54
|
+
chalk.yellow("Workflow already exists:"),
|
|
55
|
+
path.relative(getRootDir(), dest),
|
|
56
|
+
);
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
fs.mkdirSync(path.resolve(getRootDir(), ".github/workflows"), {
|
|
60
|
+
recursive: true,
|
|
61
|
+
});
|
|
62
|
+
copyTemplateFileSync("mops-publish.yml", dest);
|
|
63
|
+
console.log(chalk.green("Created"), path.relative(getRootDir(), dest));
|
|
64
|
+
} else if (templateName?.startsWith("license:")) {
|
|
65
|
+
let dest = path.resolve(getRootDir(), "LICENSE");
|
|
66
|
+
if (fs.existsSync(dest)) {
|
|
67
|
+
console.log(chalk.yellow("LICENSE already exists"));
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
56
70
|
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
71
|
+
let setYearAndOwner = (file: string) => {
|
|
72
|
+
let license = fs.readFileSync(file).toString();
|
|
73
|
+
license = license.replace(/<year>/g, new Date().getFullYear().toString());
|
|
74
|
+
if (options.copyrightOwner) {
|
|
75
|
+
license = license.replace(/<copyright-owner>/g, options.copyrightOwner);
|
|
76
|
+
}
|
|
77
|
+
fs.writeFileSync(file, license);
|
|
78
|
+
};
|
|
65
79
|
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
80
|
+
if (templateName === "license:MIT") {
|
|
81
|
+
copyTemplateFileSync(
|
|
82
|
+
"licenses/MIT",
|
|
83
|
+
path.resolve(getRootDir(), "LICENSE"),
|
|
84
|
+
);
|
|
85
|
+
setYearAndOwner(path.resolve(getRootDir(), "LICENSE"));
|
|
86
|
+
console.log(
|
|
87
|
+
chalk.green("Created"),
|
|
88
|
+
path.relative(getRootDir(), "LICENSE"),
|
|
89
|
+
);
|
|
90
|
+
} else if (templateName === "license:Apache-2.0") {
|
|
91
|
+
copyTemplateFileSync(
|
|
92
|
+
"licenses/Apache-2.0",
|
|
93
|
+
path.resolve(getRootDir(), "LICENSE"),
|
|
94
|
+
);
|
|
95
|
+
copyTemplateFileSync(
|
|
96
|
+
"licenses/Apache-2.0-NOTICE",
|
|
97
|
+
path.resolve(getRootDir(), "NOTICE"),
|
|
98
|
+
);
|
|
99
|
+
setYearAndOwner(path.resolve(getRootDir(), "NOTICE"));
|
|
100
|
+
console.log(
|
|
101
|
+
chalk.green("Created"),
|
|
102
|
+
path.relative(getRootDir(), "LICENSE"),
|
|
103
|
+
);
|
|
104
|
+
console.log(
|
|
105
|
+
chalk.green("Created"),
|
|
106
|
+
path.relative(getRootDir(), "NOTICE"),
|
|
107
|
+
);
|
|
108
|
+
}
|
|
109
|
+
} else if (templateName === "lib.mo") {
|
|
110
|
+
fs.mkdirSync(path.join(getRootDir(), "src"), { recursive: true });
|
|
111
|
+
copyTemplateFileSync(
|
|
112
|
+
"src/lib.mo",
|
|
113
|
+
path.resolve(getRootDir(), "src/lib.mo"),
|
|
114
|
+
);
|
|
115
|
+
console.log(
|
|
116
|
+
chalk.green("Created"),
|
|
117
|
+
path.relative(getRootDir(), "src/lib.mo"),
|
|
118
|
+
);
|
|
119
|
+
} else if (templateName === "lib.test.mo") {
|
|
120
|
+
fs.mkdirSync(path.join(getRootDir(), "test"), { recursive: true });
|
|
121
|
+
copyTemplateFileSync(
|
|
122
|
+
"test/lib.test.mo",
|
|
123
|
+
path.resolve(getRootDir(), "test/lib.test.mo"),
|
|
124
|
+
);
|
|
125
|
+
console.log(
|
|
126
|
+
chalk.green("Created"),
|
|
127
|
+
path.relative(getRootDir(), "test/lib.test.mo"),
|
|
128
|
+
);
|
|
129
|
+
} else if (templateName === "readme") {
|
|
130
|
+
let dest = path.resolve(getRootDir(), "README.md");
|
|
131
|
+
if (fs.existsSync(dest)) {
|
|
132
|
+
console.log(chalk.yellow("README.md already exists"));
|
|
133
|
+
return;
|
|
134
|
+
}
|
|
135
|
+
copyTemplateFileSync("README.md", dest);
|
|
96
136
|
|
|
97
|
-
|
|
137
|
+
let config = readConfig();
|
|
98
138
|
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
139
|
+
let data = fs.readFileSync(dest).toString();
|
|
140
|
+
data = data.replace(/<year>/g, new Date().getFullYear().toString());
|
|
141
|
+
if (config.package?.name) {
|
|
142
|
+
data = data.replace(/<name>/g, kebabCase(config.package.name));
|
|
143
|
+
data = data.replace(/<import-name>/g, pascalCase(config.package.name));
|
|
144
|
+
}
|
|
145
|
+
fs.writeFileSync(dest, data);
|
|
106
146
|
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
147
|
+
console.log(
|
|
148
|
+
chalk.green("Created"),
|
|
149
|
+
path.relative(getRootDir(), "README.md"),
|
|
150
|
+
);
|
|
151
|
+
}
|
|
152
|
+
}
|
package/commands/test/mmf1.ts
CHANGED
|
@@ -2,136 +2,163 @@
|
|
|
2
2
|
// mops:1:start
|
|
3
3
|
// mops:1:end
|
|
4
4
|
// mops:1:skip
|
|
5
|
-
import chalk from
|
|
5
|
+
import chalk from "chalk";
|
|
6
6
|
|
|
7
|
-
type Strategy =
|
|
8
|
-
type TestStatus =
|
|
9
|
-
type MessageType =
|
|
7
|
+
type Strategy = "store" | "print";
|
|
8
|
+
type TestStatus = "pass" | "fail" | "skip";
|
|
9
|
+
type MessageType = "pass" | "fail" | "skip" | "suite" | "stdout";
|
|
10
10
|
|
|
11
11
|
export class MMF1 {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
12
|
+
file: string;
|
|
13
|
+
stack: string[] = [];
|
|
14
|
+
currSuite: string = "";
|
|
15
|
+
failed = 0;
|
|
16
|
+
passed = 0;
|
|
17
|
+
skipped = 0;
|
|
18
|
+
strategy: Strategy;
|
|
19
|
+
output: {
|
|
20
|
+
type: MessageType;
|
|
21
|
+
message: string;
|
|
22
|
+
}[] = [];
|
|
23
|
+
nestingSymbol = " › ";
|
|
24
|
+
// or <file>
|
|
25
|
+
// or <file> › <test>
|
|
26
|
+
// or <file> › <suite> › <test>
|
|
27
|
+
// or <file> › <suite> › <test> › <nested-test>...
|
|
28
|
+
passedNamesFlat: string[] = [];
|
|
29
29
|
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
30
|
+
constructor(strategy: Strategy, file: string) {
|
|
31
|
+
this.strategy = strategy;
|
|
32
|
+
this.file = file;
|
|
33
|
+
}
|
|
34
34
|
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
}
|
|
35
|
+
_log(type: MessageType, ...args: string[]) {
|
|
36
|
+
if (this.strategy === "store") {
|
|
37
|
+
this.output.push({
|
|
38
|
+
type,
|
|
39
|
+
message: args.join(" "),
|
|
40
|
+
});
|
|
41
|
+
} else if (this.strategy === "print") {
|
|
42
|
+
console.log(...args);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
46
45
|
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
46
|
+
flush(messageType?: MessageType) {
|
|
47
|
+
for (let out of this.output) {
|
|
48
|
+
if (!messageType || out.type === messageType) {
|
|
49
|
+
console.log(out.message);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
this.output = [];
|
|
53
|
+
}
|
|
55
54
|
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
55
|
+
getErrorMessages() {
|
|
56
|
+
return this.output
|
|
57
|
+
.filter((out) => out.type === "fail")
|
|
58
|
+
.map((out) => out.message);
|
|
59
|
+
}
|
|
59
60
|
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
61
|
+
parseLine(line: string) {
|
|
62
|
+
if (line.startsWith("mops:1:start ")) {
|
|
63
|
+
this._testStart(line.split("mops:1:start ")[1] || "");
|
|
64
|
+
} else if (line.startsWith("mops:1:end ")) {
|
|
65
|
+
this._testEnd(line.split("mops:1:end ")[1] || "");
|
|
66
|
+
} else if (line.startsWith("mops:1:skip ")) {
|
|
67
|
+
this._testSkip(line.split("mops:1:skip ")[1] || "");
|
|
68
|
+
} else if (line.startsWith("mops:")) {
|
|
69
|
+
// ignore unknown mops messages
|
|
70
|
+
} else {
|
|
71
|
+
this._log(
|
|
72
|
+
"stdout",
|
|
73
|
+
" ".repeat(this.stack.length * 2),
|
|
74
|
+
chalk.gray("stdout"),
|
|
75
|
+
line,
|
|
76
|
+
);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
77
79
|
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
80
|
+
_testStart(name: string) {
|
|
81
|
+
let suite = this.stack[this.stack.length - 1];
|
|
82
|
+
if (suite) {
|
|
83
|
+
if (this.currSuite !== suite) {
|
|
84
|
+
this.currSuite = suite;
|
|
85
|
+
this._log(
|
|
86
|
+
"suite",
|
|
87
|
+
" ".repeat((this.stack.length - 1) * 2),
|
|
88
|
+
chalk.gray("•") + "",
|
|
89
|
+
suite,
|
|
90
|
+
);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
this.stack.push(name);
|
|
94
|
+
}
|
|
88
95
|
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
96
|
+
_testEnd(name: string) {
|
|
97
|
+
let last = this.stack.pop();
|
|
98
|
+
if (name !== last) {
|
|
99
|
+
console.error(`Expected test name "${last}" but got "${name}"`);
|
|
100
|
+
console.error(`Stack: ${this.stack.join(" › ")}`);
|
|
101
|
+
console.error(`File: ${this.file}`);
|
|
102
|
+
throw "mmf1._testEnd: start and end test mismatch";
|
|
103
|
+
}
|
|
104
|
+
this._status(name, "pass");
|
|
105
|
+
}
|
|
99
106
|
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
107
|
+
_testSkip(name: string) {
|
|
108
|
+
this._status(name, "skip");
|
|
109
|
+
}
|
|
103
110
|
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
111
|
+
_status(name: string, status: TestStatus) {
|
|
112
|
+
if (status === "pass") {
|
|
113
|
+
// do not print suite at the end
|
|
114
|
+
if (name === this.currSuite) {
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
117
|
+
this.passed++;
|
|
118
|
+
this._log(
|
|
119
|
+
status,
|
|
120
|
+
" ".repeat(this.stack.length * 2),
|
|
121
|
+
chalk.green("✓"),
|
|
122
|
+
name,
|
|
123
|
+
);
|
|
124
|
+
this.passedNamesFlat.push(
|
|
125
|
+
[this.file, ...this.stack, name].join(this.nestingSymbol),
|
|
126
|
+
);
|
|
127
|
+
} else if (status === "fail") {
|
|
128
|
+
this.failed++;
|
|
129
|
+
this._log(
|
|
130
|
+
status,
|
|
131
|
+
" ".repeat(this.stack.length * 2),
|
|
132
|
+
chalk.red("✖"),
|
|
133
|
+
name,
|
|
134
|
+
);
|
|
135
|
+
} else if (status === "skip") {
|
|
136
|
+
this.skipped++;
|
|
137
|
+
this._log(
|
|
138
|
+
status,
|
|
139
|
+
" ".repeat(this.stack.length * 2),
|
|
140
|
+
chalk.yellow("−"),
|
|
141
|
+
name,
|
|
142
|
+
);
|
|
143
|
+
}
|
|
144
|
+
}
|
|
123
145
|
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
146
|
+
fail(stderr: string) {
|
|
147
|
+
let name = this.stack.pop() || "";
|
|
148
|
+
this._status(name, "fail");
|
|
149
|
+
this._log(
|
|
150
|
+
"fail",
|
|
151
|
+
" ".repeat(this.stack.length * 2),
|
|
152
|
+
chalk.red("FAIL"),
|
|
153
|
+
stderr,
|
|
154
|
+
);
|
|
155
|
+
}
|
|
129
156
|
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
}
|
|
157
|
+
pass() {
|
|
158
|
+
let name = this.stack.pop();
|
|
159
|
+
if (name) {
|
|
160
|
+
this._status(name, "pass");
|
|
161
|
+
}
|
|
162
|
+
this._log("pass", " ".repeat(this.stack.length * 2), chalk.green("PASS"));
|
|
163
|
+
}
|
|
164
|
+
}
|