summaryrefslogtreecommitdiff
path: root/www/wiki/extensions/UploadWizard/tests/qunit/uw.EventFlowLogger.test.js
blob: 15b896cb9b70fc769128a4fb49b65cf0c9e6a5fd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/*
 * This file is part of the MediaWiki extension UploadWizard.
 *
 * UploadWizard is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 2 of the License, or
 * (at your option) any later version.
 *
 * UploadWizard is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with UploadWizard.  If not, see <http://www.gnu.org/licenses/>.
 */

( function ( mw, uw ) {
	QUnit.module( 'uw.EventFlowLogger', QUnit.newMwEnvironment() );

	QUnit.test( 'sanity test', function ( assert ) {
		var logger = new uw.EventFlowLogger();
		this.sandbox.stub( mw, 'track' );

		delete uw.EventFlowLogger.flowId;
		delete uw.EventFlowLogger.flowPosition;

		logger.logStep( 'foo' );
		logger.logSkippedStep( 'bar' );
		logger.logEvent( 'baz' );
		assert.ok( mw.track.calledThrice, 'all steps were logged' );
		assert.strictEqual( mw.track.firstCall.args[ 1 ].flowPosition, 1, 'first event has position 1' );
		assert.strictEqual( mw.track.thirdCall.args[ 1 ].flowPosition, 3, 'third event has position 3' );
		assert.ok( mw.track.firstCall.args[ 1 ].flowId, 'events have a flowId' );
		assert.strictEqual( mw.track.firstCall.args[ 1 ].flowId,
			mw.track.thirdCall.args[ 1 ].flowId, 'flowId is constant' );
	} );
}( mediaWiki, mediaWiki.uploadWizard ) );