mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Thanks
synced 2024-12-18 17:30:31 +00:00
aaaa5b63da
* Don't require a jQuery element with a specific attribute to record thanks. Instead pass in the thanked ID directly. * In Flow, don't override the cookieName static property, instead pass it in as an argument. Change the static property (effectively a global) prevents us from having multiple types of thanks on the same page. Change-Id: Ia569f8636f070f2af69f89d7da66c9a6f9821d24
64 lines
2.7 KiB
JavaScript
64 lines
2.7 KiB
JavaScript
QUnit.module( 'Thanks thank', QUnit.newMwEnvironment( {
|
|
setup: function () {
|
|
this.server = this.sandbox.useFakeServer();
|
|
this.server.respondImmediately = true;
|
|
}
|
|
} ) );
|
|
|
|
QUnit.test( 'thanked cookie', function ( assert ) {
|
|
var thankId = '8';
|
|
var thankIdNonExisting = '13';
|
|
|
|
mw.cookie.set( mw.thanks.thanked.cookieName, escape( '17,11' ) );
|
|
|
|
assert.deepEqual( mw.thanks.thanked.load(), [ '17', '11' ], 'gets cookie with two values' );
|
|
|
|
// Makes the 0 100th element
|
|
// eslint-disable-next-line no-restricted-properties
|
|
mw.cookie.set( mw.thanks.thanked.cookieName, escape( '9,'.repeat( mw.thanks.thanked.maxHistory - 1 ) + '0' ) );
|
|
|
|
assert.strictEqual( mw.thanks.thanked.load()[ mw.thanks.thanked.maxHistory - 1 ], '0', 'loads ' + mw.thanks.thanked.maxHistory + ' ids from a cookie' );
|
|
mw.thanks.thanked.push( thankId );
|
|
assert.strictEqual( mw.thanks.thanked.load().length, mw.thanks.thanked.maxHistory, 'cuts a cookie to ' + mw.thanks.thanked.maxHistory + ' values' );
|
|
assert.strictEqual( mw.thanks.thanked.load()[ mw.thanks.thanked.maxHistory - 1 ], thankId, 'adds a new value to cookie to the end' );
|
|
|
|
assert.strictEqual( mw.thanks.thanked.contains( thankId ), true, 'cookie contains id and returns true' );
|
|
assert.strictEqual( mw.thanks.thanked.contains( thankIdNonExisting ), false, 'cookie does not contains id and returns false' );
|
|
} );
|
|
|
|
QUnit.test( 'gets user gender', function ( assert ) {
|
|
this.server.respond( /user1/, function ( request ) {
|
|
request.respond( 200, { 'Content-Type': 'application/json' },
|
|
'{"batchcomplete":"","query":{"users":[{"userid":1,"name":"user1","gender":"male"}]}}'
|
|
);
|
|
} );
|
|
this.server.respond( /user2/, function ( request ) {
|
|
request.respond( 200, { 'Content-Type': 'application/json' },
|
|
'{"batchcomplete":"","query":{"users":[{"userid":2,"name":"user2","gender":"unknown"}]}}'
|
|
);
|
|
} );
|
|
this.server.respond( /user3/, function ( request ) {
|
|
request.respond( 200, { 'Content-Type': 'application/json' },
|
|
'{"batchcomplete":"","query":{"users":[{"name":"user3","missing":""}]}}'
|
|
);
|
|
} );
|
|
|
|
var maleUser = mw.thanks.getUserGender( 'user1' ),
|
|
unknownGenderUser = mw.thanks.getUserGender( 'user2' ),
|
|
nonExistingUser = mw.thanks.getUserGender( 'user3' ),
|
|
callbackDone = assert.async( 3 );
|
|
|
|
maleUser.then( function ( recipientGender ) {
|
|
assert.strictEqual( recipientGender, 'male', 'gets a proper gender for existing male user' );
|
|
callbackDone();
|
|
} );
|
|
unknownGenderUser.then( function ( recipientGender ) {
|
|
assert.strictEqual( recipientGender, 'unknown', 'gets a unknown gender for a existing unknown gender user' );
|
|
callbackDone();
|
|
} );
|
|
nonExistingUser.then( function ( recipientGender ) {
|
|
assert.strictEqual( recipientGender, 'unknown', 'gets a unknown gender for non-existing user' );
|
|
callbackDone();
|
|
} );
|
|
} );
|