Files
zulip/frontend_tests/node_tests/settings_profile_fields.js
Yashashvi Dave d7ee2aced1 models: Add external_account in custom profile field types.
Add new custom profile field type, External account.
External account field links user's social media
profile with account. e.g. GitHub, Twitter, etc.

Fixes part of #12302
2019-07-09 17:21:54 -07:00

182 lines
4.9 KiB
JavaScript

set_global('page_params', {});
set_global('$', global.make_zjquery());
set_global('templates', {});
set_global('loading', {});
set_global('Sortable', {create: () => {}});
const SHORT_TEXT_ID = 1;
const CHOICE_ID = 3;
const EXTERNAL_ACCOUNT_ID = 7;
const SHORT_TEXT_NAME = "Short Text";
const CHOICE_NAME = "Choice";
const EXTERNAL_ACCOUNT_NAME = "External account";
page_params.custom_profile_fields = {};
page_params.realm_default_external_accounts = JSON.stringify({});
page_params.custom_profile_field_types = {
SHORT_TEXT: {
id: SHORT_TEXT_ID,
name: SHORT_TEXT_NAME,
},
CHOICE: {
id: CHOICE_ID,
name: CHOICE_NAME,
},
EXTERNAL_ACCOUNT: {
id: EXTERNAL_ACCOUNT_ID,
name: EXTERNAL_ACCOUNT_NAME,
},
};
zrequire('settings_profile_fields');
function test_populate(opts) {
const fields_data = opts.fields_data;
page_params.is_admin = opts.is_admin;
const table = $('#admin_profile_fields_table');
const rows = $.create('rows');
const form = $.create('forms');
table.set_find_results('tr.profile-field-row', rows);
table.set_find_results('tr.profile-field-form', form);
var num_appends = 0;
table.append = () => {
num_appends += 1;
};
loading.destroy_indicator = () => {};
const template_data = [];
templates.render = (fn, data) => {
assert.equal(fn, 'admin_profile_field_list');
template_data.push(data);
return 'whatever';
};
settings_profile_fields.do_populate_profile_fields(fields_data);
assert.deepEqual(template_data, opts.expected_template_data);
assert.equal(num_appends, fields_data.length);
}
run_test('populate_profile_fields', () => {
const fields_data = [
{
type: SHORT_TEXT_ID,
id: 10,
name: 'favorite color',
hint: 'blue?',
field_data: '',
},
{
type: CHOICE_ID,
id: 30,
name: 'meal',
hint: 'lunch',
field_data: JSON.stringify([
{
text: 'lunch',
order: 0,
},
{
text: 'dinner',
order: 1,
},
]),
},
{
type: EXTERNAL_ACCOUNT_ID,
id: 20,
name: 'github profile',
hint: 'username only',
field_data: JSON.stringify({
subtype: 'github',
}),
},
{
type: EXTERNAL_ACCOUNT_ID,
id: 21,
name: 'zulip profile',
hint: 'username only',
field_data: JSON.stringify({
subtype: 'custom',
url_pattern: 'https://chat.zulip.com/%(username)s',
}),
},
];
const expected_template_data = [
{
profile_field: {
id: 10,
name: 'favorite color',
hint: 'blue?',
type: SHORT_TEXT_NAME,
choices: [],
is_choice_field: false,
is_external_account_field: false,
},
can_modify: true,
realm_default_external_accounts:
page_params.realm_default_external_accounts,
},
{
profile_field: {
id: 30,
name: 'meal',
hint: 'lunch',
type: CHOICE_NAME,
choices: [
{order: 0, value: 0, text: 'lunch'},
{order: 1, value: 1, text: 'dinner'},
],
is_choice_field: true,
is_external_account_field: false,
},
can_modify: true,
realm_default_external_accounts:
page_params.realm_default_external_accounts,
},
{
profile_field: {
id: 20,
name: 'github profile',
hint: 'username only',
type: EXTERNAL_ACCOUNT_NAME,
choices: [],
is_choice_field: false,
is_external_account_field: true,
},
can_modify: true,
realm_default_external_accounts:
page_params.realm_default_external_accounts,
},
{
profile_field: {
id: 21,
name: 'zulip profile',
hint: 'username only',
type: EXTERNAL_ACCOUNT_NAME,
choices: [],
is_choice_field: false,
is_external_account_field: true,
},
can_modify: true,
realm_default_external_accounts:
page_params.realm_default_external_accounts,
},
];
test_populate({
fields_data: fields_data,
expected_template_data: expected_template_data,
is_admin: true,
});
});