mirror of
https://github.com/PrivateBin/PrivateBin.git
synced 2024-03-22 13:10:41 +08:00
90 lines
3.6 KiB
JavaScript
90 lines
3.6 KiB
JavaScript
'use strict';
|
|
var common = require('../common');
|
|
|
|
describe('InitialCheck', function () {
|
|
describe('init', function () {
|
|
this.timeout(30000);
|
|
before(function () {
|
|
cleanup();
|
|
});
|
|
|
|
it('returns false and shows error, if a bot UA is detected', function () {
|
|
jsc.assert(jsc.forall(
|
|
'string',
|
|
jsc.elements(['Bot', 'bot']),
|
|
'string',
|
|
function (prefix, botBit, suffix) {
|
|
const clean = jsdom('', {
|
|
'userAgent': prefix + botBit + suffix
|
|
});
|
|
$('body').html(
|
|
'<html><body><div id="errormessage" class="hidden"></div>' +
|
|
'</body></html>'
|
|
);
|
|
$.PrivateBin.Alert.init();
|
|
const result1 = !$.PrivateBin.InitialCheck.init(),
|
|
result2 = !$('#errormessage').hasClass('hidden');
|
|
clean();
|
|
return result1 && result2;
|
|
}
|
|
),
|
|
{tests: 10});
|
|
});
|
|
|
|
jsc.property(
|
|
'shows error, if no webcrypto is detected',
|
|
'bool',
|
|
jsc.elements(['localhost', '127.0.0.1', '[::1]', '']),
|
|
jsc.nearray(common.jscA2zString()),
|
|
jsc.elements(['.onion', '.i2p', '']),
|
|
function (secureProtocol, localhost, domain, tld) {
|
|
const isDomain = localhost === '',
|
|
isSecureContext = secureProtocol || !isDomain || tld.length > 0,
|
|
clean = jsdom('', {
|
|
'url': (secureProtocol ? 'https' : 'http' ) + '://' +
|
|
(isDomain ? domain.join('') + tld : localhost) + '/'
|
|
});
|
|
$('body').html(
|
|
'<html><body><div id="errormessage" class="hidden"></div>'+
|
|
'<div id="oldnotice" class="hidden"></div></body></html>'
|
|
);
|
|
const crypto = window.crypto;
|
|
window.crypto = null;
|
|
$.PrivateBin.Alert.init();
|
|
const result1 = !$.PrivateBin.InitialCheck.init(),
|
|
result2 = isSecureContext === $('#errormessage').hasClass('hidden'),
|
|
result3 = !$('#oldnotice').hasClass('hidden');
|
|
window.crypto = crypto;
|
|
clean();
|
|
return result1 && result2 && result3;
|
|
}
|
|
);
|
|
|
|
jsc.property(
|
|
'shows error, if HTTP only site is detected',
|
|
'bool',
|
|
jsc.elements(['localhost', '127.0.0.1', '[::1]', '']),
|
|
jsc.nearray(common.jscA2zString()),
|
|
jsc.elements(['.onion', '.i2p', '']),
|
|
function (secureProtocol, localhost, domain, tld) {
|
|
const isDomain = localhost === '',
|
|
isSecureContext = secureProtocol || !isDomain || tld.length > 0,
|
|
clean = jsdom('', {
|
|
'url': (secureProtocol ? 'https' : 'http' ) + '://' +
|
|
(isDomain ? domain.join('') + tld : localhost) + '/'
|
|
});
|
|
$('body').html(
|
|
'<html><body><div id="httpnotice" class="hidden"></div>'+
|
|
'</body></html>'
|
|
);
|
|
$.PrivateBin.Alert.init();
|
|
const result1 = $.PrivateBin.InitialCheck.init(),
|
|
result2 = isSecureContext === $('#httpnotice').hasClass('hidden');
|
|
clean();
|
|
return result1 && result2;
|
|
}
|
|
);
|
|
});
|
|
});
|
|
|