summaryrefslogtreecommitdiff
path: root/tests/regression.test.ts
diff options
context:
space:
mode:
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(() => {});
+});