/**
* Get date user registered, if available
*
- * @return {Date|boolean|null} Date user registered, or false for anonymous users, or
- * null when data is not available
+ * @return {boolean|null|Date} False for anonymous users, null if data is
+ * unavailable, or Date for when the user registered.
*/
getRegistration: function () {
- var registration = mw.config.get( 'wgUserRegistration' );
if ( mw.user.isAnon() ) {
return false;
}
- if ( registration === null ) {
- // Information may not be available if they signed up before
- // MW began storing this.
- return null;
- }
- return new Date( registration );
+ var registration = mw.config.get( 'wgUserRegistration' );
+ // Registration may be unavailable if the user signed up before MediaWiki
+ // began tracking this.
+ return !registration ? null : new Date( registration );
},
/**
}
} ) );
- QUnit.test( 'options', 1, function ( assert ) {
+ QUnit.test( 'options', function ( assert ) {
assert.ok( mw.user.options instanceof mw.Map, 'options instance of mw.Map' );
} );
- QUnit.test( 'user status', 7, function ( assert ) {
-
+ QUnit.test( 'getters (anonymous)', function ( assert ) {
// Forge an anonymous user
mw.config.set( 'wgUserName', null );
delete mw.config.values.wgUserId;
- assert.strictEqual( mw.user.getName(), null, 'user.getName() returns null when anonymous' );
- assert.assertTrue( mw.user.isAnon(), 'user.isAnon() returns true when anonymous' );
- assert.strictEqual( mw.user.getId(), 0, 'user.getId() returns 0 when anonymous' );
+ assert.strictEqual( mw.user.getName(), null, 'getName()' );
+ assert.strictEqual( mw.user.isAnon(), true, 'isAnon()' );
+ assert.strictEqual( mw.user.getId(), 0, 'getId()' );
+ } );
- // Not part of startUp module
+ QUnit.test( 'getters (logged-in)', function ( assert ) {
mw.config.set( 'wgUserName', 'John' );
mw.config.set( 'wgUserId', 123 );
- assert.equal( mw.user.getName(), 'John', 'user.getName() returns username when logged-in' );
- assert.assertFalse( mw.user.isAnon(), 'user.isAnon() returns false when logged-in' );
- assert.strictEqual( mw.user.getId(), 123, 'user.getId() returns correct ID when logged-in' );
+ assert.equal( mw.user.getName(), 'John', 'getName()' );
+ assert.strictEqual( mw.user.isAnon(), false, 'isAnon()' );
+ assert.strictEqual( mw.user.getId(), 123, 'getId()' );
- assert.equal( mw.user.id(), 'John', 'user.id Returns username when logged-in' );
+ assert.equal( mw.user.id(), 'John', 'user.id()' );
} );
- QUnit.test( 'getUserInfos', 3, function ( assert ) {
+ QUnit.test( 'getUserInfo', function ( assert ) {
mw.config.set( 'wgUserGroups', [ '*', 'user' ] );
mw.user.getGroups( function ( groups ) {
this.server.respond();
} );
- QUnit.test( 'generateRandomSessionId', 4, function ( assert ) {
+ QUnit.test( 'generateRandomSessionId', function ( assert ) {
var result, result2;
result = mw.user.generateRandomSessionId();
} );
- QUnit.test( 'generateRandomSessionId (fallback)', 4, function ( assert ) {
+ QUnit.test( 'generateRandomSessionId (fallback)', function ( assert ) {
var result, result2;
// Pretend crypto API is not there to test the Math.random fallback