diff options
| author | Florian Dold <florian.dold@gmail.com> | 2020-07-27 17:09:52 +0530 | 
|---|---|---|
| committer | Florian Dold <florian.dold@gmail.com> | 2020-07-27 17:09:52 +0530 | 
| commit | ae111663f412ad7bee9029110e3ab1594ec14576 (patch) | |
| tree | 7fc51632c328774c390b989e7f2e6dfd3c31751d /src/util/taleruri-test.ts | |
| parent | 694d913d1f226b3d284258286c73a035fd43da7d (diff) | |
new taler:// URI syntax
Diffstat (limited to 'src/util/taleruri-test.ts')
| -rw-r--r-- | src/util/taleruri-test.ts | 101 | 
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");  }); | 
