zulip/frontend_tests/node_tests/billing.js

102 lines
3.4 KiB
JavaScript

const noop = () => {};
const { JSDOM } = require("jsdom");
const fs = require("fs");
const template = fs.readFileSync("templates/corporate/billing.html", "utf-8");
const dom = new JSDOM(template, { pretendToBeVisual: true });
const document = dom.window.document;
let jquery_init;
global.$ = (f) => {jquery_init = f;};
set_global('helpers', {
set_tab: noop,
});
set_global('StripeCheckout', {
configure: noop,
});
zrequire('billing', "js/billing/billing");
set_global('$', global.make_zjquery());
run_test("initialize", () => {
let token_func;
let set_tab_called = false;
helpers.set_tab = (page_name) => {
assert.equal(page_name, "billing");
set_tab_called = true;
};
let create_ajax_request_called = false;
helpers.create_ajax_request = (url, form_name, stripe_token) => {
assert.equal(url, "/json/billing/sources/change");
assert.equal(form_name, "cardchange");
assert.equal(stripe_token, "stripe_token");
create_ajax_request_called = true;
};
let open_func_called = false;
const open_func = (config_opts) => {
assert.equal(config_opts.name, "Zulip");
assert.equal(config_opts.zipCode, true);
assert.equal(config_opts.billingAddress, true);
assert.equal(config_opts.panelLabel, "Update card");
assert.equal(config_opts.label, "Update card");
assert.equal(config_opts.allowRememberMe, false);
assert.equal(config_opts.email, "{{stripe_email}}");
token_func("stripe_token");
open_func_called = true;
};
let stripe_checkout_configure_called = false;
StripeCheckout.configure = (config_opts) => {
assert.equal(config_opts.image, '/static/images/logo/zulip-icon-128x128.png');
assert.equal(config_opts.locale, 'auto');
assert.equal(config_opts.key, '{{publishable_key}}');
token_func = config_opts.token;
stripe_checkout_configure_called = true;
return {
open: open_func,
};
};
$("#payment-method").data = (key) => document.querySelector("#payment-method").getAttribute("data-" + key);
jquery_init();
assert(set_tab_called);
assert(stripe_checkout_configure_called);
const e = {
preventDefault: noop,
};
const update_card_click_handler = $('#update-card-button').get_on_handler('click');
update_card_click_handler(e);
assert(create_ajax_request_called);
assert(open_func_called);
create_ajax_request_called = false;
helpers.create_ajax_request = (url, form_name, stripe_token, numeric_inputs) => {
assert.equal(url, "/json/billing/plan/change");
assert.equal(form_name, "planchange");
assert.equal(stripe_token, undefined);
assert.deepEqual(numeric_inputs, ["status"]);
create_ajax_request_called = true;
};
const change_plan_status_click_handler = $('#change-plan-status').get_on_handler('click');
change_plan_status_click_handler(e);
assert(create_ajax_request_called);
});
run_test("billing_template", () => {
// Elements necessary for create_ajax_request
assert(document.querySelector("#cardchange-error"));
assert(document.querySelector("#cardchange-loading"));
assert(document.querySelector("#cardchange_loading_indicator"));
assert(document.querySelector("#cardchange-success"));
assert(document.querySelector("input[name=csrfmiddlewaretoken]"));
});