discourse/test/javascripts/widgets/home-logo-test.js.es6

148 lines
4.4 KiB
Plaintext
Raw Normal View History

2018-06-15 23:03:24 +08:00
import { moduleForWidget, widgetTest } from "helpers/widget-test";
2016-03-22 02:16:05 +08:00
2018-06-15 23:03:24 +08:00
moduleForWidget("home-logo");
2016-03-22 02:16:05 +08:00
2018-06-15 23:03:24 +08:00
const bigLogo = "/images/d-logo-sketch.png?test";
const smallLogo = "/images/d-logo-sketch-small.png?test";
const mobileLogo = "/images/d-logo-sketch.png?mobile";
2016-03-22 02:16:05 +08:00
const title = "Cool Forum";
2018-06-15 23:03:24 +08:00
widgetTest("basics", {
template: '{{mount-widget widget="home-logo" args=args}}',
2017-06-15 01:57:58 +08:00
beforeEach() {
2018-11-14 15:03:02 +08:00
this.siteSettings.site_logo_url = bigLogo;
this.siteSettings.site_logo_small_url = smallLogo;
2016-03-22 02:16:05 +08:00
this.siteSettings.title = title;
2018-06-15 23:03:24 +08:00
this.set("args", { minimized: false });
2016-03-22 02:16:05 +08:00
},
test(assert) {
2018-06-15 23:03:24 +08:00
assert.ok(this.$(".title").length === 1);
2016-03-22 02:16:05 +08:00
2018-06-15 23:03:24 +08:00
assert.ok(this.$("img#site-logo.logo-big").length === 1);
assert.equal(this.$("#site-logo").attr("src"), bigLogo);
assert.equal(this.$("#site-logo").attr("alt"), title);
}
});
2016-03-22 02:16:05 +08:00
2018-06-15 23:03:24 +08:00
widgetTest("basics - minimized", {
template: '{{mount-widget widget="home-logo" args=args}}',
2017-06-15 01:57:58 +08:00
beforeEach() {
2018-11-14 15:03:02 +08:00
this.siteSettings.site_logo_url = bigLogo;
this.siteSettings.site_logo_small_url = smallLogo;
this.siteSettings.title = title;
2018-06-15 23:03:24 +08:00
this.set("args", { minimized: true });
},
test(assert) {
2018-06-15 23:03:24 +08:00
assert.ok(this.$("img.logo-small").length === 1);
assert.equal(this.$("img.logo-small").attr("src"), smallLogo);
assert.equal(this.$("img.logo-small").attr("alt"), title);
2016-03-22 02:16:05 +08:00
}
});
2018-06-15 23:03:24 +08:00
widgetTest("no logo", {
template: '{{mount-widget widget="home-logo" args=args}}',
2017-06-15 01:57:58 +08:00
beforeEach() {
2018-11-14 15:03:02 +08:00
this.siteSettings.site_logo_url = "";
this.siteSettings.site_logo_small_url = "";
2016-03-22 02:16:05 +08:00
this.siteSettings.title = title;
2018-06-15 23:03:24 +08:00
this.set("args", { minimized: false });
2016-03-22 02:16:05 +08:00
},
test(assert) {
2018-06-15 23:03:24 +08:00
assert.ok(this.$("h1#site-text-logo.text-logo").length === 1);
assert.equal(this.$("#site-text-logo").text(), title);
}
});
2016-03-22 02:16:05 +08:00
2018-06-15 23:03:24 +08:00
widgetTest("no logo - minimized", {
template: '{{mount-widget widget="home-logo" args=args}}',
2017-06-15 01:57:58 +08:00
beforeEach() {
2018-11-14 15:03:02 +08:00
this.siteSettings.site_logo_url = "";
this.siteSettings.site_logo_small_url = "";
this.siteSettings.title = title;
2018-06-15 23:03:24 +08:00
this.set("args", { minimized: true });
},
test(assert) {
2018-06-15 23:03:24 +08:00
assert.ok(this.$(".d-icon-home").length === 1);
2016-03-22 02:16:05 +08:00
}
});
2018-06-15 23:03:24 +08:00
widgetTest("mobile logo", {
template: '{{mount-widget widget="home-logo" args=args}}',
2017-06-15 01:57:58 +08:00
beforeEach() {
2018-11-14 15:03:02 +08:00
this.siteSettings.site_mobile_logo_url = mobileLogo;
this.siteSettings.site_logo_small_url = smallLogo;
2016-03-22 02:16:05 +08:00
this.site.mobileView = true;
},
test(assert) {
2018-06-15 23:03:24 +08:00
assert.ok(this.$("img#site-logo.logo-big").length === 1);
assert.equal(this.$("#site-logo").attr("src"), mobileLogo);
2016-03-22 02:16:05 +08:00
}
});
2018-06-15 23:03:24 +08:00
widgetTest("mobile without logo", {
template: '{{mount-widget widget="home-logo" args=args}}',
2017-06-15 01:57:58 +08:00
beforeEach() {
2018-11-14 15:03:02 +08:00
this.siteSettings.site_logo_url = bigLogo;
2016-03-22 02:16:05 +08:00
this.site.mobileView = true;
},
test(assert) {
2018-06-15 23:03:24 +08:00
assert.ok(this.$("img#site-logo.logo-big").length === 1);
assert.equal(this.$("#site-logo").attr("src"), bigLogo);
2016-03-22 02:16:05 +08:00
}
});
widgetTest("basics, subfolder", {
template: '{{mount-widget widget="home-logo" args=args}}',
beforeEach() {
Discourse.BaseUri = "/forum";
2018-11-14 15:03:02 +08:00
this.siteSettings.site_logo_url = bigLogo;
this.siteSettings.site_logo_small_url = smallLogo;
this.siteSettings.title = title;
this.set("args", { minimized: false });
},
test(assert) {
assert.ok(this.$("img#site-logo.logo-big").length === 1);
assert.equal(this.$("#site-logo").attr("src"), `/forum${bigLogo}`);
assert.equal(this.$("#site-logo").attr("alt"), title);
}
});
widgetTest("basics, subfolder - minimized", {
template: '{{mount-widget widget="home-logo" args=args}}',
beforeEach() {
Discourse.BaseUri = "/forum";
2018-11-14 15:03:02 +08:00
this.siteSettings.site_logo_url = bigLogo;
this.siteSettings.site_logo_small_url = smallLogo;
this.siteSettings.title = title;
this.set("args", { minimized: true });
},
test(assert) {
assert.ok(this.$("img.logo-small").length === 1);
assert.equal(this.$("img.logo-small").attr("src"), `/forum${smallLogo}`);
assert.equal(this.$("img.logo-small").attr("alt"), title);
}
});
widgetTest("mobile logo, subfolder", {
template: '{{mount-widget widget="home-logo" args=args}}',
beforeEach() {
Discourse.BaseUri = "/forum";
2018-11-14 15:03:02 +08:00
this.siteSettings.site_mobile_logo_url = mobileLogo;
this.siteSettings.site_logo_small_url = smallLogo;
this.site.mobileView = true;
},
test(assert) {
assert.ok(this.$("img#site-logo.logo-big").length === 1);
assert.equal(this.$("#site-logo").attr("src"), `/forum${mobileLogo}`);
}
});