aboutsummaryrefslogtreecommitdiff
path: root/src/util/taleruri-test.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/util/taleruri-test.ts')
-rw-r--r--src/util/taleruri-test.ts101
1 files changed, 29 insertions, 72 deletions
diff --git a/src/util/taleruri-test.ts b/src/util/taleruri-test.ts
index 1510880c5..40a30bf7f 100644
--- a/src/util/taleruri-test.ts
+++ b/src/util/taleruri-test.ts
@@ -33,136 +33,93 @@ test("taler pay url parsing: wrong scheme", (t) => {
});
test("taler pay url parsing: defaults", (t) => {
- const url1 = "taler://pay/example.com/-/-/myorder";
+ const url1 = "taler://pay/example.com/myorder/";
const r1 = parsePayUri(url1);
if (!r1) {
t.fail();
return;
}
- t.is(r1.merchantBaseUrl, "https://example.com/public/");
- t.is(r1.sessionId, undefined);
+ t.is(r1.merchantBaseUrl, "https://example.com/");
+ t.is(r1.sessionId, "");
- const url2 = "taler://pay/example.com/-/-/myorder/mysession";
+ const url2 = "taler://pay/example.com/myorder/mysession";
const r2 = parsePayUri(url2);
if (!r2) {
t.fail();
return;
}
- t.is(r2.merchantBaseUrl, "https://example.com/public/");
+ t.is(r2.merchantBaseUrl, "https://example.com/");
t.is(r2.sessionId, "mysession");
});
-test("taler pay url parsing: trailing parts", (t) => {
- const url1 = "taler://pay/example.com/-/-/myorder/mysession/spam/eggs";
- const r1 = parsePayUri(url1);
- if (!r1) {
- t.fail();
- return;
- }
- t.is(r1.merchantBaseUrl, "https://example.com/public/");
- t.is(r1.sessionId, "mysession");
-});
-
test("taler pay url parsing: instance", (t) => {
- const url1 = "taler://pay/example.com/-/myinst/myorder";
+ const url1 = "taler://pay/example.com/instances/myinst/myorder/";
const r1 = parsePayUri(url1);
if (!r1) {
t.fail();
return;
}
- t.is(r1.merchantBaseUrl, "https://example.com/public/instances/myinst/");
+ t.is(r1.merchantBaseUrl, "https://example.com/instances/myinst/");
t.is(r1.orderId, "myorder");
});
-test("taler pay url parsing: path prefix and instance", (t) => {
- const url1 = "taler://pay/example.com/mypfx/myinst/myorder";
- const r1 = parsePayUri(url1);
- if (!r1) {
- t.fail();
- return;
- }
- t.is(r1.merchantBaseUrl, "https://example.com/mypfx/instances/myinst/");
-});
-
-test("taler pay url parsing: complex path prefix", (t) => {
- const url1 = "taler://pay/example.com/mypfx%2Fpublic/-/myorder";
- const r1 = parsePayUri(url1);
- if (!r1) {
- t.fail();
- return;
- }
- t.is(r1.merchantBaseUrl, "https://example.com/mypfx/public/");
- t.is(r1.orderId, "myorder");
- t.is(r1.sessionId, undefined);
-});
-
-test("taler pay uri parsing: complex path prefix and instance", (t) => {
- const url1 = "taler://pay/example.com/mypfx%2Fpublic/foo/myorder";
- const r1 = parsePayUri(url1);
- if (!r1) {
- t.fail();
- return;
- }
- t.is(r1.merchantBaseUrl, "https://example.com/mypfx/public/instances/foo/");
- t.is(r1.orderId, "myorder");
-});
test("taler refund uri parsing: non-https #1", (t) => {
- const url1 = "taler://refund/example.com/-/-/myorder?insecure=1";
+ const url1 = "taler+http://refund/example.com/myorder";
const r1 = parseRefundUri(url1);
if (!r1) {
t.fail();
return;
}
- t.is(r1.merchantBaseUrl, "http://example.com/public/");
+ t.is(r1.merchantBaseUrl, "http://example.com/");
t.is(r1.orderId, "myorder");
});
-test("taler pay uri parsing: non-https #1", (t) => {
- const url1 = "taler://pay/example.com/-/-/myorder?insecure=1";
+test("taler pay uri parsing: non-https", (t) => {
+ const url1 = "taler+http://pay/example.com/myorder/";
const r1 = parsePayUri(url1);
if (!r1) {
t.fail();
return;
}
- t.is(r1.merchantBaseUrl, "http://example.com/public/");
+ t.is(r1.merchantBaseUrl, "http://example.com/");
t.is(r1.orderId, "myorder");
});
-test("taler pay url parsing: non-https #2", (t) => {
- const url1 = "taler://pay/example.com/-/-/myorder?insecure=2";
+test("taler pay uri parsing: missing session component", (t) => {
+ const url1 = "taler+http://pay/example.com/myorder";
const r1 = parsePayUri(url1);
- if (!r1) {
+ if (r1) {
t.fail();
return;
}
- t.is(r1.merchantBaseUrl, "https://example.com/public/");
- t.is(r1.orderId, "myorder");
+ t.pass();
});
test("taler withdraw uri parsing", (t) => {
- const url1 = "taler://withdraw/bank.example.com/-/12345";
+ const url1 = "taler://withdraw/bank.example.com/12345";
const r1 = parseWithdrawUri(url1);
if (!r1) {
t.fail();
return;
}
- t.is(r1.statusUrl, "https://bank.example.com/api/withdraw-operation/12345");
+ t.is(r1.withdrawalOperationId, "12345");
+ t.is(r1.bankIntegrationApiBaseUrl, "https://bank.example.com/");
});
test("taler refund uri parsing", (t) => {
- const url1 = "taler://refund/merchant.example.com/-/-/1234";
+ const url1 = "taler://refund/merchant.example.com/1234";
const r1 = parseRefundUri(url1);
if (!r1) {
t.fail();
return;
}
- t.is(r1.merchantBaseUrl, "https://merchant.example.com/public/");
+ t.is(r1.merchantBaseUrl, "https://merchant.example.com/");
t.is(r1.orderId, "1234");
});
test("taler refund uri parsing with instance", (t) => {
- const url1 = "taler://refund/merchant.example.com/-/myinst/1234";
+ const url1 = "taler://refund/merchant.example.com/instances/myinst/1234";
const r1 = parseRefundUri(url1);
if (!r1) {
t.fail();
@@ -171,22 +128,22 @@ test("taler refund uri parsing with instance", (t) => {
t.is(r1.orderId, "1234");
t.is(
r1.merchantBaseUrl,
- "https://merchant.example.com/public/instances/myinst/",
+ "https://merchant.example.com/instances/myinst/",
);
});
test("taler tip pickup uri", (t) => {
- const url1 = "taler://tip/merchant.example.com/-/-/tipid";
+ const url1 = "taler://tip/merchant.example.com/tipid";
const r1 = parseTipUri(url1);
if (!r1) {
t.fail();
return;
}
- t.is(r1.merchantBaseUrl, "https://merchant.example.com/public/");
+ t.is(r1.merchantBaseUrl, "https://merchant.example.com/");
});
test("taler tip pickup uri with instance", (t) => {
- const url1 = "taler://tip/merchant.example.com/-/tipm/tipid";
+ const url1 = "taler://tip/merchant.example.com/instances/tipm/tipid";
const r1 = parseTipUri(url1);
if (!r1) {
t.fail();
@@ -194,13 +151,13 @@ test("taler tip pickup uri with instance", (t) => {
}
t.is(
r1.merchantBaseUrl,
- "https://merchant.example.com/public/instances/tipm/",
+ "https://merchant.example.com/instances/tipm/",
);
t.is(r1.merchantTipId, "tipid");
});
test("taler tip pickup uri with instance and prefix", (t) => {
- const url1 = "taler://tip/merchant.example.com/my%2fpfx/tipm/tipid";
+ const url1 = "taler://tip/merchant.example.com/my/pfx/tipm/tipid";
const r1 = parseTipUri(url1);
if (!r1) {
t.fail();
@@ -208,7 +165,7 @@ test("taler tip pickup uri with instance and prefix", (t) => {
}
t.is(
r1.merchantBaseUrl,
- "https://merchant.example.com/my/pfx/instances/tipm/",
+ "https://merchant.example.com/my/pfx/tipm/",
);
t.is(r1.merchantTipId, "tipid");
});