node tests: Add test() wrapper for stream_data.

This commit is contained in:
Steve Howell
2021-03-12 19:07:54 +00:00
committed by Steve Howell
parent 154daf353b
commit 88357579fe

View File

@@ -7,11 +7,7 @@ const _ = require("lodash");
const {set_global, zrequire} = require("../zjsunit/namespace"); const {set_global, zrequire} = require("../zjsunit/namespace");
const {run_test} = require("../zjsunit/test"); const {run_test} = require("../zjsunit/test");
const page_params = set_global("page_params", { let page_params;
is_admin: false,
realm_users: [],
is_guest: false,
});
const color_data = zrequire("color_data"); const color_data = zrequire("color_data");
const stream_topic_history = zrequire("stream_topic_history"); const stream_topic_history = zrequire("stream_topic_history");
@@ -28,14 +24,26 @@ const me = {
}; };
// set up user data // set up user data
people.add_active_user(me);
people.initialize_current_user(me.user_id);
function contains_sub(subs, sub) { function contains_sub(subs, sub) {
return subs.some((s) => s.name === sub.name); return subs.some((s) => s.name === sub.name);
} }
run_test("basics", () => { function test(label, f) {
run_test(label, (override) => {
page_params = set_global("page_params", {
is_admin: false,
realm_users: [],
is_guest: false,
});
people.init();
people.add_active_user(me);
people.initialize_current_user(me.user_id);
stream_data.clear_subscriptions();
f(override);
});
}
test("basics", () => {
const denmark = { const denmark = {
subscribed: false, subscribed: false,
color: "blue", color: "blue",
@@ -119,8 +127,7 @@ run_test("basics", () => {
assert.equal(stream_data.slug_to_name("99whatever"), "99whatever"); assert.equal(stream_data.slug_to_name("99whatever"), "99whatever");
}); });
run_test("renames", () => { test("renames", () => {
stream_data.clear_subscriptions();
const id = 42; const id = 42;
let sub = { let sub = {
name: "Denmark", name: "Denmark",
@@ -149,9 +156,7 @@ run_test("renames", () => {
assert.equal(actual_id, 42); assert.equal(actual_id, 42);
}); });
run_test("is_active", () => { test("is_active", () => {
stream_data.clear_subscriptions();
let sub; let sub;
page_params.demote_inactive_streams = page_params.demote_inactive_streams =
@@ -235,7 +240,7 @@ run_test("is_active", () => {
assert(stream_data.is_active(sub)); assert(stream_data.is_active(sub));
}); });
run_test("admin_options", () => { test("admin_options", () => {
function make_sub() { function make_sub() {
const sub = { const sub = {
subscribed: false, subscribed: false,
@@ -285,7 +290,7 @@ run_test("admin_options", () => {
assert(sub.can_change_stream_permissions); assert(sub.can_change_stream_permissions);
}); });
run_test("stream_settings", () => { test("stream_settings", () => {
const cinnamon = { const cinnamon = {
stream_id: 1, stream_id: 1,
name: "c", name: "c",
@@ -312,7 +317,6 @@ run_test("stream_settings", () => {
stream_post_policy: stream_data.stream_post_policy_values.admins.code, stream_post_policy: stream_data.stream_post_policy_values.admins.code,
message_retention_days: 10, message_retention_days: 10,
}; };
stream_data.clear_subscriptions();
stream_data.add_sub(cinnamon); stream_data.add_sub(cinnamon);
stream_data.add_sub(amber); stream_data.add_sub(amber);
stream_data.add_sub(blue); stream_data.add_sub(blue);
@@ -360,7 +364,7 @@ run_test("stream_settings", () => {
assert.equal(sub_rows.length, 2); assert.equal(sub_rows.length, 2);
}); });
run_test("default_stream_names", () => { test("default_stream_names", () => {
const announce = { const announce = {
stream_id: 101, stream_id: 101,
name: "announce", name: "announce",
@@ -387,7 +391,6 @@ run_test("default_stream_names", () => {
invite_only: false, invite_only: false,
}; };
stream_data.clear_subscriptions();
stream_data.set_realm_default_streams([announce, general]); stream_data.set_realm_default_streams([announce, general]);
stream_data.add_sub(announce); stream_data.add_sub(announce);
stream_data.add_sub(public_stream); stream_data.add_sub(public_stream);
@@ -401,14 +404,13 @@ run_test("default_stream_names", () => {
assert.deepEqual(default_stream_ids.sort(), [announce.stream_id, general.stream_id]); assert.deepEqual(default_stream_ids.sort(), [announce.stream_id, general.stream_id]);
}); });
run_test("delete_sub", () => { test("delete_sub", () => {
const canada = { const canada = {
stream_id: 101, stream_id: 101,
name: "Canada", name: "Canada",
subscribed: true, subscribed: true,
}; };
stream_data.clear_subscriptions();
stream_data.add_sub(canada); stream_data.add_sub(canada);
assert(stream_data.is_subscribed("Canada")); assert(stream_data.is_subscribed("Canada"));
@@ -424,7 +426,7 @@ run_test("delete_sub", () => {
stream_data.delete_sub(99999); stream_data.delete_sub(99999);
}); });
run_test("notifications", () => { test("notifications", () => {
const india = { const india = {
stream_id: 102, stream_id: 102,
name: "India", name: "India",
@@ -437,7 +439,6 @@ run_test("notifications", () => {
push_notifications: null, push_notifications: null,
wildcard_mentions_notify: null, wildcard_mentions_notify: null,
}; };
stream_data.clear_subscriptions();
stream_data.add_sub(india); stream_data.add_sub(india);
assert(!stream_data.receives_notifications(india.stream_id, "desktop_notifications")); assert(!stream_data.receives_notifications(india.stream_id, "desktop_notifications"));
@@ -588,7 +589,7 @@ const jazy = {
is_muted: true, is_muted: true,
}; };
run_test("is_muted", () => { test("is_muted", () => {
stream_data.add_sub(tony); stream_data.add_sub(tony);
stream_data.add_sub(jazy); stream_data.add_sub(jazy);
assert(!stream_data.is_stream_muted_by_name("tony")); assert(!stream_data.is_stream_muted_by_name("tony"));
@@ -596,7 +597,7 @@ run_test("is_muted", () => {
assert(stream_data.is_stream_muted_by_name("EEXISTS")); assert(stream_data.is_stream_muted_by_name("EEXISTS"));
}); });
run_test("is_notifications_stream_muted", () => { test("is_notifications_stream_muted", () => {
stream_data.add_sub(tony); stream_data.add_sub(tony);
stream_data.add_sub(jazy); stream_data.add_sub(jazy);
@@ -607,14 +608,14 @@ run_test("is_notifications_stream_muted", () => {
assert(stream_data.is_notifications_stream_muted()); assert(stream_data.is_notifications_stream_muted());
}); });
run_test("realm_has_notifications_stream", () => { test("realm_has_notifications_stream", () => {
page_params.realm_notifications_stream_id = 10; page_params.realm_notifications_stream_id = 10;
assert(stream_data.realm_has_notifications_stream()); assert(stream_data.realm_has_notifications_stream());
page_params.realm_notifications_stream_id = -1; page_params.realm_notifications_stream_id = -1;
assert(!stream_data.realm_has_notifications_stream()); assert(!stream_data.realm_has_notifications_stream());
}); });
run_test("remove_default_stream", () => { test("remove_default_stream", () => {
const remove_me = { const remove_me = {
stream_id: 674, stream_id: 674,
name: "remove_me", name: "remove_me",
@@ -628,12 +629,11 @@ run_test("remove_default_stream", () => {
assert(!stream_data.is_default_stream_id(remove_me.stream_id)); assert(!stream_data.is_default_stream_id(remove_me.stream_id));
}); });
run_test("canonicalized_name", () => { test("canonicalized_name", () => {
assert.deepStrictEqual(stream_data.canonicalized_name("Stream_Bar"), "stream_bar"); assert.deepStrictEqual(stream_data.canonicalized_name("Stream_Bar"), "stream_bar");
}); });
run_test("create_sub", (override) => { test("create_sub", (override) => {
stream_data.clear_subscriptions();
const india = { const india = {
stream_id: 102, stream_id: 102,
name: "India", name: "India",
@@ -673,7 +673,7 @@ run_test("create_sub", (override) => {
assert.equal(antarctica_sub.color, "#76ce90"); assert.equal(antarctica_sub.color, "#76ce90");
}); });
run_test("initialize", () => { test("initialize", () => {
function get_params() { function get_params() {
const params = {}; const params = {};
@@ -736,7 +736,10 @@ run_test("initialize", () => {
assert.equal(stream_data.get_notifications_stream(), "foo"); assert.equal(stream_data.get_notifications_stream(), "foo");
}); });
run_test("filter inactives", () => { test("filter inactives", () => {
page_params.demote_inactive_streams =
settings_config.demote_inactive_streams_values.automatic.code;
const params = {}; const params = {};
params.unsubscribed = []; params.unsubscribed = [];
params.never_subscribed = []; params.never_subscribed = [];
@@ -762,14 +765,14 @@ run_test("filter inactives", () => {
assert(stream_data.is_filtering_inactives()); assert(stream_data.is_filtering_inactives());
}); });
run_test("edge_cases", () => { test("edge_cases", () => {
const bad_stream_ids = [555555, 99999]; const bad_stream_ids = [555555, 99999];
// just make sure we don't explode // just make sure we don't explode
stream_data.sort_for_stream_settings(bad_stream_ids); stream_data.sort_for_stream_settings(bad_stream_ids);
}); });
run_test("get_invite_stream_data", () => { test("get_invite_stream_data", () => {
// add default stream // add default stream
const orie = { const orie = {
name: "Orie", name: "Orie",
@@ -778,8 +781,6 @@ run_test("get_invite_stream_data", () => {
subscribed: true, subscribed: true,
}; };
// clear all the data form stream_data, and people
stream_data.clear_subscriptions();
people.init(); people.init();
stream_data.add_sub(orie); stream_data.add_sub(orie);
@@ -812,7 +813,7 @@ run_test("get_invite_stream_data", () => {
assert.deepEqual(stream_data.get_invite_stream_data(), expected_list); assert.deepEqual(stream_data.get_invite_stream_data(), expected_list);
}); });
run_test("all_topics_in_cache", () => { test("all_topics_in_cache", () => {
// Add a new stream with first_message_id set. // Add a new stream with first_message_id set.
const general = { const general = {
name: "general", name: "general",