141 lines
5.3 KiB
JavaScript
141 lines
5.3 KiB
JavaScript
/* jshint expr: true */
|
|
|
|
var assert = chai.assert;
|
|
var expect = chai.expect;
|
|
|
|
import * as Log from '../core/util/logging.js';
|
|
import l10nGet, { l10n } from '../core/util/localization.js';
|
|
|
|
import 'sinon';
|
|
import sinonChai from '../node_modules/sinon-chai/lib/sinon-chai.js'
|
|
chai.use(sinonChai);
|
|
|
|
describe('Utils', function() {
|
|
"use strict";
|
|
|
|
describe('logging functions', function () {
|
|
beforeEach(function () {
|
|
sinon.spy(console, 'log');
|
|
sinon.spy(console, 'debug');
|
|
sinon.spy(console, 'warn');
|
|
sinon.spy(console, 'error');
|
|
sinon.spy(console, 'info');
|
|
});
|
|
|
|
afterEach(function () {
|
|
console.log.restore();
|
|
console.debug.restore();
|
|
console.warn.restore();
|
|
console.error.restore();
|
|
console.info.restore();
|
|
});
|
|
|
|
it('should use noop for levels lower than the min level', function () {
|
|
Log.init_logging('warn');
|
|
Log.Debug('hi');
|
|
Log.Info('hello');
|
|
expect(console.log).to.not.have.been.called;
|
|
});
|
|
|
|
it('should use console.debug for Debug', function () {
|
|
Log.init_logging('debug');
|
|
Log.Debug('dbg');
|
|
expect(console.debug).to.have.been.calledWith('dbg');
|
|
});
|
|
|
|
it('should use console.info for Info', function () {
|
|
Log.init_logging('debug');
|
|
Log.Info('inf');
|
|
expect(console.info).to.have.been.calledWith('inf');
|
|
});
|
|
|
|
it('should use console.warn for Warn', function () {
|
|
Log.init_logging('warn');
|
|
Log.Warn('wrn');
|
|
expect(console.warn).to.have.been.called;
|
|
expect(console.warn).to.have.been.calledWith('wrn');
|
|
});
|
|
|
|
it('should use console.error for Error', function () {
|
|
Log.init_logging('error');
|
|
Log.Error('err');
|
|
expect(console.error).to.have.been.called;
|
|
expect(console.error).to.have.been.calledWith('err');
|
|
});
|
|
});
|
|
|
|
describe('language selection', function () {
|
|
var origNavigator;
|
|
beforeEach(function () {
|
|
// window.navigator is a protected read-only property in many
|
|
// environments, so we need to redefine it whilst running these
|
|
// tests.
|
|
origNavigator = Object.getOwnPropertyDescriptor(window, "navigator");
|
|
if (origNavigator === undefined) {
|
|
// Object.getOwnPropertyDescriptor() doesn't work
|
|
// properly in any version of IE
|
|
this.skip();
|
|
}
|
|
|
|
Object.defineProperty(window, "navigator", {value: {}});
|
|
if (window.navigator.languages !== undefined) {
|
|
// Object.defineProperty() doesn't work properly in old
|
|
// versions of Chrome
|
|
this.skip();
|
|
}
|
|
|
|
window.navigator.languages = [];
|
|
});
|
|
afterEach(function () {
|
|
Object.defineProperty(window, "navigator", origNavigator);
|
|
});
|
|
|
|
it('should use English by default', function() {
|
|
expect(l10n.language).to.equal('en');
|
|
});
|
|
it('should use English if no user language matches', function() {
|
|
window.navigator.languages = ["nl", "de"];
|
|
l10n.setup(["es", "fr"]);
|
|
expect(l10n.language).to.equal('en');
|
|
});
|
|
it('should use the most preferred user language', function() {
|
|
window.navigator.languages = ["nl", "de", "fr"];
|
|
l10n.setup(["es", "fr", "de"]);
|
|
expect(l10n.language).to.equal('de');
|
|
});
|
|
it('should prefer sub-languages languages', function() {
|
|
window.navigator.languages = ["pt-BR"];
|
|
l10n.setup(["pt", "pt-BR"]);
|
|
expect(l10n.language).to.equal('pt-BR');
|
|
});
|
|
it('should fall back to language "parents"', function() {
|
|
window.navigator.languages = ["pt-BR"];
|
|
l10n.setup(["fr", "pt", "de"]);
|
|
expect(l10n.language).to.equal('pt');
|
|
});
|
|
it('should not use specific language when user asks for a generic language', function() {
|
|
window.navigator.languages = ["pt", "de"];
|
|
l10n.setup(["fr", "pt-BR", "de"]);
|
|
expect(l10n.language).to.equal('de');
|
|
});
|
|
it('should handle underscore as a separator', function() {
|
|
window.navigator.languages = ["pt-BR"];
|
|
l10n.setup(["pt_BR"]);
|
|
expect(l10n.language).to.equal('pt_BR');
|
|
});
|
|
it('should handle difference in case', function() {
|
|
window.navigator.languages = ["pt-br"];
|
|
l10n.setup(["pt-BR"]);
|
|
expect(l10n.language).to.equal('pt-BR');
|
|
});
|
|
});
|
|
|
|
// TODO(directxman12): test the conf_default and conf_defaults methods
|
|
// TODO(directxman12): test decodeUTF8
|
|
// TODO(directxman12): test the event methods (addEvent, removeEvent, stopEvent)
|
|
// TODO(directxman12): figure out a good way to test getPosition and getEventPosition
|
|
// TODO(directxman12): figure out how to test the browser detection functions properly
|
|
// (we can't really test them against the browsers, except for Gecko
|
|
// via PhantomJS, the default test driver)
|
|
});
|