summaryrefslogtreecommitdiff
path: root/www/wiki/extensions/UploadWizard/tests/qunit/uw.EventFlowLogger.test.js
diff options
context:
space:
mode:
Diffstat (limited to 'www/wiki/extensions/UploadWizard/tests/qunit/uw.EventFlowLogger.test.js')
-rw-r--r--www/wiki/extensions/UploadWizard/tests/qunit/uw.EventFlowLogger.test.js38
1 files changed, 38 insertions, 0 deletions
diff --git a/www/wiki/extensions/UploadWizard/tests/qunit/uw.EventFlowLogger.test.js b/www/wiki/extensions/UploadWizard/tests/qunit/uw.EventFlowLogger.test.js
new file mode 100644
index 00000000..15b896cb
--- /dev/null
+++ b/www/wiki/extensions/UploadWizard/tests/qunit/uw.EventFlowLogger.test.js
@@ -0,0 +1,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 ) );