summaryrefslogtreecommitdiff
path: root/tests/regression.test.ts
diff options
context:
space:
mode:
authorIm-Beast <franik.mateusz@gmail.com>2024-10-14 17:01:44 +0200
committerIm-Beast <franik.mateusz@gmail.com>2024-10-14 17:01:44 +0200
commitde8c27c0f528738a3377f3e6b4a0ee729d3ce4d8 (patch)
tree1cbb8d226ae029160f0481c6fc8e327d5c951e6c /tests/regression.test.ts
parent44fd5e17bbce52caf681850ac79f463d9ce6bb31 (diff)
regression tests
Diffstat (limited to 'tests/regression.test.ts')
-rwxr-xr-xtests/regression.test.ts34
1 files changed, 34 insertions, 0 deletions
diff --git a/tests/regression.test.ts b/tests/regression.test.ts
new file mode 100755
index 0000000..677f9b6
--- /dev/null
+++ b/tests/regression.test.ts
@@ -0,0 +1,34 @@
+import { $, createWalletViaCli, downloadMoneroCli, getMoneroC, getMoneroCTags } from "./utils.ts";
+
+Deno.test("Regression tests", async (t) => {
+ await Deno.remove("./tests/wallets", { recursive: true }).catch(() => {});
+ await Deno.mkdir("./tests/wallets", { recursive: true });
+
+ const tags = await getMoneroCTags();
+ const latestTag = tags[0];
+ await Promise.all([getMoneroC("next"), await getMoneroC(latestTag), downloadMoneroCli()]);
+
+ await t.step("Simple (next, latest, next)", async () => {
+ const walletInfo = await createWalletViaCli("dog", "sobaka");
+
+ for (const version of ["next", latestTag, "next"]) {
+ await $`deno run -A ./tests/compare.ts ${version} ${JSON.stringify(walletInfo)}`;
+ }
+ });
+
+ await t.step("All releases sequentially (all tags in the release order, next)", async () => {
+ tags.unshift("next");
+
+ const walletInfo = await createWalletViaCli("cat", "koshka");
+
+ for (const version of tags.toReversed()) {
+ if (version !== "next" && version !== tags[0]) await getMoneroC(version);
+ await $`deno run -A ./tests/compare.ts ${version} ${JSON.stringify(walletInfo)}`;
+ }
+
+ await Deno.remove("./tests/wallets", { recursive: true }).catch(() => {});
+ });
+
+ await Deno.remove("./tests/wallets", { recursive: true }).catch(() => {});
+ await Deno.remove("./tests/libs", { recursive: true }).catch(() => {});
+});