From 87239df82e907a17af7a8f1d7dd819d0da5e7af3 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 01:23:57 +0100 Subject: [PATCH 01/26] assert.strictEqual --- test/helpers/default-functions.ts | 3 +- test/specs/confirm_edit/confirm-edit.ts | 4 +- test/specs/fedprops/item.ts | 2 +- test/specs/fedprops/prefetching.ts | 14 ++--- test/specs/pingback/pingback.ts | 10 ++-- test/specs/quickstatements/quickstatements.ts | 52 +++++++------------ test/specs/repo/api.ts | 5 +- test/specs/repo/extensions/babel.ts | 17 +++--- test/specs/repo/extensions/entityschema.ts | 8 +-- test/specs/repo/extensions/nuke.ts | 5 +- test/specs/repo/extensions/scribunto.ts | 2 +- .../extensions/universal-language-selector.ts | 4 +- test/specs/repo/extensions/visual-editor.ts | 4 +- test/specs/repo/extensions/wikibase-edtf.ts | 7 ++- .../repo/extensions/wikibase-local-media.ts | 5 +- .../repo/extensions/wikibase-manifest.ts | 21 +++----- test/specs/repo/queryservice.ts | 10 ++-- test/specs/repo/search.ts | 3 +- test/specs/repo/special-item.ts | 9 ++-- test/specs/repo/special-version.ts | 3 +- test/specs/repo_client/item.ts | 4 +- test/specs/upgrade/pre-upgrade.ts | 9 ++-- .../upgrade/queryservice-post-upgrade.ts | 10 ++-- .../queryservice-pre-and-post-upgrade.ts | 16 +++--- test/specs/upgrade/upgrade.ts | 12 ++--- 25 files changed, 94 insertions(+), 145 deletions(-) diff --git a/test/helpers/default-functions.ts b/test/helpers/default-functions.ts index 943aa8617..716406e75 100644 --- a/test/helpers/default-functions.ts +++ b/test/helpers/default-functions.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import axios, { AxiosResponse } from 'axios'; import lodash from 'lodash'; import { Context } from 'mocha'; @@ -176,7 +175,7 @@ export function defaultFunctions(): void { const changes = result.data.query.recentchanges; const foundResult = lodash.find( changes, expectedChange ); - assert.strictEqual( result.status, 200 ); + expect( result.status ).toBe( 200 ); if ( !foundResult ) { testEnv.testLog.error( 'Could not find:' ); diff --git a/test/specs/confirm_edit/confirm-edit.ts b/test/specs/confirm_edit/confirm-edit.ts index 5973a8df8..64af96912 100644 --- a/test/specs/confirm_edit/confirm-edit.ts +++ b/test/specs/confirm_edit/confirm-edit.ts @@ -1,5 +1,3 @@ -import assert from 'assert'; - describe( 'ConfirmEdit', function () { it( 'Should allow to edit with captcha', async function () { const executionResult = await browser.editPage( @@ -9,6 +7,6 @@ describe( 'ConfirmEdit', function () { 'paris' ); - assert.strictEqual( executionResult, 'something great' ); + expect( executionResult ).toBe( 'something great' ); } ); } ); diff --git a/test/specs/fedprops/item.ts b/test/specs/fedprops/item.ts index 0a94d5616..c233c9265 100644 --- a/test/specs/fedprops/item.ts +++ b/test/specs/fedprops/item.ts @@ -20,7 +20,7 @@ describe( 'Fed props Item', function () { const success = result.data.success; const searchResults = result.data.search; - assert.strictEqual( success, 1 ); + expect( success ).toBe( 1 ); assert( searchResults.length > 0 ); } ); diff --git a/test/specs/fedprops/prefetching.ts b/test/specs/fedprops/prefetching.ts index 429c7342b..0fc882065 100644 --- a/test/specs/fedprops/prefetching.ts +++ b/test/specs/fedprops/prefetching.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import { getTestString } from 'wdio-mediawiki/Util.js'; import WikibaseApi from 'wdio-wikibase/wikibase.api.js'; import ItemPage from '../../helpers/pages/entity/item.page.js'; @@ -34,7 +33,7 @@ describe( 'Property Prefetching', function () { }; } ) ); - assert.strictEqual( claims.length, NUM_PROPERTIES ); + expect( claims.length ).toBe( NUM_PROPERTIES ); const data = { claims: claims }; itemId = await WikibaseApi.createItem( getTestString( itemLabel ), data ); @@ -51,11 +50,11 @@ describe( 'Property Prefetching', function () { statements.map( async ( statement ) => statement.getAttribute( 'id' ) ) ); - assert.strictEqual( propertyGuids.length, NUM_PROPERTIES ); + expect( propertyGuids.length ).toBe( NUM_PROPERTIES ); for ( const guid of propertyGuids ) { const response = await browser.deleteClaim( guid ); - assert.strictEqual( response.success, 1 ); + expect( response.success ).toBe( 1 ); } // Sleep for 2 seconds to ensure post edit things run @@ -68,10 +67,7 @@ describe( 'Property Prefetching', function () { await $( '#pagehistory' ); // +1 for the initial item creation - assert.strictEqual( - ( await $$( '#pagehistory li' ) ).length, - NUM_PROPERTIES + 1 - ); + expect( ( await $$( '#pagehistory li' ) ).length ).toBe( NUM_PROPERTIES + 1 ); } ); it( 'Should render recent changes list within threshold', async function () { @@ -83,6 +79,6 @@ describe( 'Property Prefetching', function () { // +1 for the initial item creation // +1 for the Main Page creation? // +1 for ? - assert.strictEqual( ( await $$( 'ul.special li' ) ).length, NUM_PROPERTIES + 3 ); + expect( ( await $$( 'ul.special li' ) ).length ).toBe( NUM_PROPERTIES + 3 ); } ); } ); diff --git a/test/specs/pingback/pingback.ts b/test/specs/pingback/pingback.ts index 934552137..4a4b949fe 100644 --- a/test/specs/pingback/pingback.ts +++ b/test/specs/pingback/pingback.ts @@ -1,5 +1,3 @@ -import assert from 'assert'; - describe( 'Pingback', function () { it( 'Should ping on first page request', async function () { await browser.url( testEnv.vars.WIKIBASE_URL + '/wiki/Main_Page' ); @@ -10,16 +8,16 @@ describe( 'Pingback', function () { const sqlResult = await browser.dbQuery( 'SELECT * from updatelog where ul_key LIKE "WikibasePingback%"' ); - assert.strictEqual( sqlResult.includes( 'WikibasePingback\t' ), true ); - assert.strictEqual( sqlResult.includes( 'WikibasePingback-1.' ), true ); + expect( sqlResult.includes( 'WikibasePingback\t' ) ).toBe( true ); + expect( sqlResult.includes( 'WikibasePingback-1.' ) ).toBe( true ); const result = await browser.makeRequest( 'http://mediawiki.svc' ); - assert.strictEqual( result.data.length, 2 ); + expect( result.data.length ).toBe( 2 ); const requestData = JSON.parse( Object.keys( result.data[ 0 ] )[ 0 ].replace( ';', '' ) ); - assert.strictEqual( requestData.schema, 'WikibasePingback' ); + expect( requestData.schema ).toBe( 'WikibasePingback' ); } ); } ); diff --git a/test/specs/quickstatements/quickstatements.ts b/test/specs/quickstatements/quickstatements.ts index 9ea4f34fd..c7e864938 100644 --- a/test/specs/quickstatements/quickstatements.ts +++ b/test/specs/quickstatements/quickstatements.ts @@ -107,8 +107,8 @@ describe( 'QuickStatements Service', function () { const responseQ1Data = await SpecialEntityDataPage.getData( 'Q1' ); const responseQ2Data = await SpecialEntityDataPage.getData( 'Q2' ); - assert.strictEqual( responseQ1Data.entities.Q1.id, 'Q1' ); - assert.strictEqual( responseQ2Data.entities.Q2.id, 'Q2' ); + expect( responseQ1Data.entities.Q1.id ).toBe( 'Q1' ); + expect( responseQ2Data.entities.Q2.id ).toBe( 'Q2' ); } ); it( 'Should be able to create item with label', async function () { @@ -118,10 +118,7 @@ describe( 'QuickStatements Service', function () { const responseQ3Data = await SpecialEntityDataPage.getData( 'Q3' ); - assert.strictEqual( - responseQ3Data.entities.Q3.labels.en.value, - 'Best label' - ); + expect( responseQ3Data.entities.Q3.labels.en.value ).toBe( 'Best label' ); } ); it( 'Should be able to create an item with statement', async function () { @@ -182,14 +179,12 @@ describe( 'QuickStatements Service', function () { await browser.executeQuickStatement( `Q1|${ propertyId }|"Will it blend?"` ); const responseQ1Data = await SpecialEntityDataPage.getData( 'Q1' ); - assert.strictEqual( - responseQ1Data.entities.Q1.claims[ propertyId ][ 0 ].type, + expect( responseQ1Data.entities.Q1.claims[ propertyId ][ 0 ].type ).toBe( 'statement' ); - assert.strictEqual( - responseQ1Data.entities.Q1.claims[ propertyId ][ 0 ].mainsnak.datavalue.value, - 'Will it blend?' - ); + expect( + responseQ1Data.entities.Q1.claims[ propertyId ][ 0 ].mainsnak.datavalue.value + ).toBe( 'Will it blend?' ); } ); describe( 'Should be able to add qualifiers to statements with a range of datatypes', function () { @@ -212,10 +207,9 @@ describe( 'QuickStatements Service', function () { const responseQ1 = await browser.makeRequest( `${ testEnv.vars.WIKIBASE_URL }/w/api.php?action=wbgetclaims&format=json&entity=${ itemId }` ); - assert.strictEqual( - getQualifierType( responseQ1, mainPropertyId, qualifierPropertyId ), - qualifierSnakDataType - ); + expect( + getQualifierType( responseQ1, mainPropertyId, qualifierPropertyId ) + ).toBe( qualifierSnakDataType ); } ); } ); } ); @@ -229,8 +223,7 @@ describe( 'QuickStatements Service', function () { ); const responseQ1Data = await SpecialEntityDataPage.getData( 'Q1' ); - assert.strictEqual( - responseQ1Data.entities.Q1.claims[ propertyId ][ 0 ].type, + expect( responseQ1Data.entities.Q1.claims[ propertyId ][ 0 ].type ).toBe( 'statement' ); } ); @@ -254,7 +247,7 @@ describe( 'QuickStatements Service', function () { ); assert( typeof refValue !== 'string' ); - assert.strictEqual( refValue.id, 'Q2' ); + expect( refValue.id ).toBe( 'Q2' ); } ); it( 'Should be able to add a property with "url" reference', async function () { @@ -272,7 +265,7 @@ describe( 'QuickStatements Service', function () { ); const refValue = getReferenceValue( response, propertyIdItem, propertyURL ); - assert.strictEqual( refValue, 'https://www.wikidata.org' ); + expect( refValue ).toBe( 'https://www.wikidata.org' ); } ); it( 'Should be able to add a property with "string" reference', async function () { @@ -288,7 +281,7 @@ describe( 'QuickStatements Service', function () { ); const refValue = getReferenceValue( response, propertyIdItem, propertyId ); - assert.strictEqual( refValue, 'some string' ); + expect( refValue ).toBe( 'some string' ); } ); it( 'Should be able to add and remove a property on an item', async function () { @@ -297,28 +290,19 @@ describe( 'QuickStatements Service', function () { await browser.executeQuickStatement( `${ itemId }|${ propertyIdItem }|Q1` ); let responseData = await SpecialEntityDataPage.getData( itemId ); - assert.strictEqual( - propertyIdItem in responseData.entities[ itemId ].claims, - true - ); + expect( propertyIdItem in responseData.entities[ itemId ].claims ).toBe( true ); await browser.executeQuickStatement( `-${ itemId }|${ propertyIdItem }|Q1` ); responseData = await SpecialEntityDataPage.getData( itemId ); - assert.strictEqual( - propertyIdItem in responseData.entities[ itemId ].claims, - false - ); + expect( propertyIdItem in responseData.entities[ itemId ].claims ).toBe( false ); } ); it( 'Should be able to change label', async function () { await browser.executeQuickStatement( 'Q1|LSv|"Some other label"' ); const responseQ1Data = await SpecialEntityDataPage.getData( 'Q1' ); - assert.strictEqual( - responseQ1Data.entities.Q1.labels.sv.value, - 'Some other label' - ); + expect( responseQ1Data.entities.Q1.labels.sv.value ).toBe( 'Some other label' ); } ); it( 'Should be able to merge two items', async function () { @@ -327,7 +311,7 @@ describe( 'QuickStatements Service', function () { await browser.executeQuickStatement( 'MERGE|Q1|Q2' ); const responseQ2Data = await SpecialEntityDataPage.getData( 'Q2' ); - assert.strictEqual( responseQ2Data.entities.Q1.id, 'Q1' ); + expect( responseQ2Data.entities.Q1.id ).toBe( 'Q1' ); } ); it( 'Should have a Last Batches button', async function () { diff --git a/test/specs/repo/api.ts b/test/specs/repo/api.ts index 6ab508a96..6290be1eb 100644 --- a/test/specs/repo/api.ts +++ b/test/specs/repo/api.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import { getTestString } from 'wdio-mediawiki/Util.js'; import WikibaseApi from 'wdio-wikibase/wikibase.api.js'; import { wikibasePropertyString } from '../../helpers/wikibase-property-types.js'; @@ -33,8 +32,8 @@ describe( 'Wikibase API', function () { data ); - assert.strictEqual( itemId.startsWith( 'Q' ), true ); - assert.strictEqual( propertyId.startsWith( 'P' ), true ); + expect( itemId.startsWith( 'Q' ) ).toBe( true ); + expect( propertyId.startsWith( 'P' ) ).toBe( true ); } ); } ); } ); diff --git a/test/specs/repo/extensions/babel.ts b/test/specs/repo/extensions/babel.ts index 44bd9b7e4..131344e0c 100644 --- a/test/specs/repo/extensions/babel.ts +++ b/test/specs/repo/extensions/babel.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import LoginPage from 'wdio-mediawiki/LoginPage.js'; describe( 'Babel', function () { @@ -18,17 +17,13 @@ describe( 'Babel', function () { '{{#babel: sv | en }}' ); - assert.strictEqual( - executionContent.includes( - 'Den här användaren har svenska som modersmål.' - ), - true - ); - assert.strictEqual( + expect( + executionContent.includes( 'Den här användaren har svenska som modersmål.' ) + ).toBe( true ); + expect( executionContent.includes( 'This user has a native understanding of English.' - ), - true - ); + ) + ).toBe( true ); } ); } ); diff --git a/test/specs/repo/extensions/entityschema.ts b/test/specs/repo/extensions/entityschema.ts index 7be421fb0..df7b99f56 100644 --- a/test/specs/repo/extensions/entityschema.ts +++ b/test/specs/repo/extensions/entityschema.ts @@ -41,10 +41,10 @@ describe( 'EntitySchema', function () { await $( '.entityschema-description' ).getText() ).trim(); - assert.strictEqual( actualDescription, testDescription ); - assert.strictEqual( actualTemplate, shexTemplate ); - assert.strictEqual( actualLabel, testLabel ); - assert.strictEqual( actualId, '(E1)' ); + expect( actualDescription ).toBe( testDescription ); + expect( actualTemplate ).toBe( shexTemplate ); + expect( actualLabel ).toBe( testLabel ); + expect( actualId ).toBe( '(E1)' ); assert.ok( actualTemplateHtml.includes( 'mw-highlight' ), 'Should contain mw-highlight class in HTML' diff --git a/test/specs/repo/extensions/nuke.ts b/test/specs/repo/extensions/nuke.ts index b9ebbb831..9abf58698 100644 --- a/test/specs/repo/extensions/nuke.ts +++ b/test/specs/repo/extensions/nuke.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import LoginPage from 'wdio-mediawiki/LoginPage.js'; describe( 'Nuke', function () { @@ -20,7 +19,7 @@ describe( 'Nuke', function () { {} ); - assert.strictEqual( pageExistsResult.status, 200 ); + expect( pageExistsResult.status ).toBe( 200 ); await LoginPage.login( testEnv.vars.MW_ADMIN_NAME, @@ -48,6 +47,6 @@ describe( 'Nuke', function () { {} ); - assert.strictEqual( pageIsGoneResult.status, 404 ); + expect( pageIsGoneResult.status ).toBe( 404 ); } ); } ); diff --git a/test/specs/repo/extensions/scribunto.ts b/test/specs/repo/extensions/scribunto.ts index 257278e4e..439a2fd35 100644 --- a/test/specs/repo/extensions/scribunto.ts +++ b/test/specs/repo/extensions/scribunto.ts @@ -36,6 +36,6 @@ describe( 'Scribunto', function () { ); assert( cpuTime.value < 0.05 ); - assert.strictEqual( cpuTime.scale, 'seconds' ); + expect( cpuTime.scale ).toBe( 'seconds' ); } ); } ); diff --git a/test/specs/repo/extensions/universal-language-selector.ts b/test/specs/repo/extensions/universal-language-selector.ts index 2ac0deff4..2d051a7c2 100644 --- a/test/specs/repo/extensions/universal-language-selector.ts +++ b/test/specs/repo/extensions/universal-language-selector.ts @@ -1,5 +1,3 @@ -import assert from 'assert'; - describe( 'UniversalLanguageSelector', function () { beforeEach( async function () { await browser.skipIfExtensionNotPresent( this, 'UniversalLanguageSelector' ); @@ -12,6 +10,6 @@ describe( 'UniversalLanguageSelector', function () { const firstLang = await $( '.imeselector-menu h3' ).getText(); - assert.strictEqual( firstLang, 'English' ); + expect( firstLang ).toBe( 'English' ); } ); } ); diff --git a/test/specs/repo/extensions/visual-editor.ts b/test/specs/repo/extensions/visual-editor.ts index 19d898f74..f61a4f8a2 100644 --- a/test/specs/repo/extensions/visual-editor.ts +++ b/test/specs/repo/extensions/visual-editor.ts @@ -1,5 +1,3 @@ -import assert from 'assert'; - describe( 'VisualEditor', function () { beforeEach( async function () { await browser.skipIfExtensionNotPresent( this, 'VisualEditor' ); @@ -35,6 +33,6 @@ describe( 'VisualEditor', function () { const contentBody = await $( '.mw-parser-output' ).getText(); - assert.strictEqual( contentBody, 'TEST' ); + expect( contentBody ).toBe( 'TEST' ); } ); } ); diff --git a/test/specs/repo/extensions/wikibase-edtf.ts b/test/specs/repo/extensions/wikibase-edtf.ts index 9dfa6ed55..e3e7746c4 100644 --- a/test/specs/repo/extensions/wikibase-edtf.ts +++ b/test/specs/repo/extensions/wikibase-edtf.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import WikibaseApi from 'wdio-wikibase/wikibase.api.js'; import ItemPage from '../../../helpers/pages/entity/item.page.js'; import SpecialEntityDataPage from '../../../helpers/pages/special/entity-data.page.js'; @@ -12,7 +11,7 @@ describe( 'WikibaseEdtf', function () { it( 'Should allow to create and use the EDTF property', async function () { // create the property const propertyId = await WikibaseApi.createProperty( 'edtf' ); - assert.strictEqual( propertyId.startsWith( 'P' ), true ); + expect( propertyId.startsWith( 'P' ) ).toBe( true ); const rawValue = '1985-04-12T23:20:30'; @@ -37,8 +36,8 @@ describe( 'WikibaseEdtf', function () { const responseSnak = responseData.entities[ itemId ].claims[ propertyId ][ 0 ].mainsnak; - assert.strictEqual( responseSnak.datavalue.value, '1985-04-12T23:20:30' ); - assert.strictEqual( responseSnak.datatype, 'edtf' ); + expect( responseSnak.datavalue.value ).toBe( '1985-04-12T23:20:30' ); + expect( responseSnak.datatype ).toBe( 'edtf' ); // for a pretty screenshot await ItemPage.open( itemId ); diff --git a/test/specs/repo/extensions/wikibase-local-media.ts b/test/specs/repo/extensions/wikibase-local-media.ts index b2dfc7274..7e79a6c65 100644 --- a/test/specs/repo/extensions/wikibase-local-media.ts +++ b/test/specs/repo/extensions/wikibase-local-media.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import LoginPage from 'wdio-mediawiki/LoginPage.js'; import WikibaseApi from 'wdio-wikibase/wikibase.api.js'; import ItemPage from '../../../helpers/pages/entity/item.page.js'; @@ -32,7 +31,7 @@ describe( 'WikibaseLocalMedia', function () { it( 'Should allow to create a property with localMedia datatype', async function () { propertyId = await WikibaseApi.createProperty( 'localMedia' ); - assert.strictEqual( propertyId.startsWith( 'P' ), true ); + expect( propertyId.startsWith( 'P' ) ).toBe( true ); await PropertyPage.open( propertyId ); @@ -62,7 +61,7 @@ describe( 'WikibaseLocalMedia', function () { 'src' ); - assert.strictEqual( imageSource.includes( 'Image.png' ), true ); + expect( imageSource.includes( 'Image.png' ) ).toBe( true ); } ); it( 'Should allow to use uploaded image on statement in UI', async function () { diff --git a/test/specs/repo/extensions/wikibase-manifest.ts b/test/specs/repo/extensions/wikibase-manifest.ts index cd8277182..19bda931e 100644 --- a/test/specs/repo/extensions/wikibase-manifest.ts +++ b/test/specs/repo/extensions/wikibase-manifest.ts @@ -1,5 +1,3 @@ -import assert from 'assert'; - describe( 'WikibaseManifest', function () { beforeEach( async function () { await browser.skipIfExtensionNotPresent( this, 'WikibaseManifest' ); @@ -11,20 +9,13 @@ describe( 'WikibaseManifest', function () { ); const data = result.data; - assert.strictEqual( 'wikibase-docker', data.name ); + expect( 'wikibase-docker' ).toBe( data.name ); - assert.strictEqual( - testEnv.vars.WIKIBASE_URL + '/w/api.php', - data.api.action - ); - assert.strictEqual( - testEnv.vars.WIKIBASE_URL + '/w/rest.php', - data.api.rest - ); + expect( testEnv.vars.WIKIBASE_URL + '/w/api.php' ).toBe( data.api.action ); + expect( testEnv.vars.WIKIBASE_URL + '/w/rest.php' ).toBe( data.api.rest ); - assert.strictEqual( - testEnv.vars.WIKIBASE_URL + '/wiki/Special:OAuthConsumerRegistration', - data.oauth.registration_page - ); + expect( + testEnv.vars.WIKIBASE_URL + '/wiki/Special:OAuthConsumerRegistration' + ).toBe( data.oauth.registration_page ); } ); } ); diff --git a/test/specs/repo/queryservice.ts b/test/specs/repo/queryservice.ts index 124c01311..0940ea5ea 100644 --- a/test/specs/repo/queryservice.ts +++ b/test/specs/repo/queryservice.ts @@ -13,14 +13,14 @@ describe( 'QueryService', function () { { validateStatus: false }, {} ); - assert.strictEqual( result.status, 405 ); + expect( result.status ).toBe( 405 ); } ); it( 'Should be able to get sparql endpoint', async function () { const result = await browser.makeRequest( `${ testEnv.vars.WDQS_PROXY_URL }/bigdata/namespace/wdq/sparql` ); - assert.strictEqual( result.status, 200 ); + expect( result.status ).toBe( 200 ); } ); it( 'Should not be possible to reach blazegraph ldf api that is not enabled', async function () { @@ -28,7 +28,7 @@ describe( 'QueryService', function () { `${ testEnv.vars.WDQS_PROXY_URL }/bigdata/namespace/wdq/ldf`, { validateStatus: false } ); - assert.strictEqual( result.status, 404 ); + expect( result.status ).toBe( 404 ); } ); it( 'Should not be possible to reach blazegraph ldf assets thats not enabled', async function () { @@ -36,7 +36,7 @@ describe( 'QueryService', function () { `${ testEnv.vars.WDQS_PROXY_URL }/bigdata/namespace/wdq/assets`, { validateStatus: false } ); - assert.strictEqual( result.status, 404 ); + expect( result.status ).toBe( 404 ); } ); it( 'Should not be possible to reach blazegraph workbench', async function () { @@ -44,7 +44,7 @@ describe( 'QueryService', function () { `${ testEnv.vars.WDQS_PROXY_URL }/bigdata/#query`, { validateStatus: false } ); - assert.strictEqual( result.status, 404 ); + expect( result.status ).toBe( 404 ); } ); it( 'Should show up with property in queryservice ui after creation', async function () { diff --git a/test/specs/repo/search.ts b/test/specs/repo/search.ts index 83c2bafdf..781ec831b 100644 --- a/test/specs/repo/search.ts +++ b/test/specs/repo/search.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import WikibaseApi from 'wdio-wikibase/wikibase.api.js'; describe( 'Search', function () { @@ -15,6 +14,6 @@ describe( 'Search', function () { `${ testEnv.vars.WIKIBASE_URL }/w/api.php?action=wbsearchentities&search=${ itemLabel }&format=json&errorformat=plaintext&language=en&uselang=en&type=item` ); - assert.strictEqual( result.data.search[ 0 ].label, itemLabel ); + expect( result.data.search[ 0 ].label ).toBe( itemLabel ); } ); } ); diff --git a/test/specs/repo/special-item.ts b/test/specs/repo/special-item.ts index 8dde7bc75..02b992b4d 100644 --- a/test/specs/repo/special-item.ts +++ b/test/specs/repo/special-item.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import SpecialEntityPage from 'wdio-wikibase/pageobjects/item.page.js'; import SpecialNewItemPage from '../../helpers/pages/special/new-item.page.js'; @@ -21,21 +20,21 @@ describe( 'Special:NewItem', function () { const labelText = await $( '.wikibase-entitytermsforlanguageview-label' ).getText(); - assert.strictEqual( labelText, label ); + expect( labelText ).toBe( label ); const descriptionText = await $( '.wikibase-entitytermsforlanguageview-description' ).getText(); - assert.strictEqual( descriptionText, description ); + expect( descriptionText ).toBe( description ); const firstAliasText = await $( '.wikibase-entitytermsforlanguageview-aliases li:nth-child(1)' ).getText(); - assert.strictEqual( firstAliasText, firstAlias ); + expect( firstAliasText ).toBe( firstAlias ); const secondAliasText = await $( '.wikibase-entitytermsforlanguageview-aliases li:nth-child(2)' ).getText(); - assert.strictEqual( secondAliasText, secondAlias ); + expect( secondAliasText ).toBe( secondAlias ); } ); } ); diff --git a/test/specs/repo/special-version.ts b/test/specs/repo/special-version.ts index bb076caf2..a2e6913aa 100644 --- a/test/specs/repo/special-version.ts +++ b/test/specs/repo/special-version.ts @@ -4,8 +4,7 @@ describe( 'Special:Version', function () { it( 'Should contain the correct MediaWiki version', async function () { await browser.url( `${ testEnv.vars.WIKIBASE_URL }/wiki/Special:Version` ); const text = await $( '#sv-software' ).getText(); - assert.strictEqual( - text.includes( `MediaWiki ${ testEnv.vars.MEDIAWIKI_VERSION }` ), + expect( text.includes( `MediaWiki ${ testEnv.vars.MEDIAWIKI_VERSION }` ) ).toBe( true ); } ); diff --git a/test/specs/repo_client/item.ts b/test/specs/repo_client/item.ts index cfe1a7dcd..ad5fa1f5d 100644 --- a/test/specs/repo_client/item.ts +++ b/test/specs/repo_client/item.ts @@ -26,13 +26,13 @@ describe( 'Item', function () { `${ testEnv.vars.WIKIBASE_CLIENT_URL }/wiki/Special:NewItem?uselang=qqx` ); const notFoundText = await SpecialNewItemPage.firstHeading.getText(); - assert.strictEqual( notFoundText, '(nosuchspecialpage)' ); + expect( notFoundText ).toBe( '(nosuchspecialpage)' ); } ); it( 'Special:NewItem should be visible on repo', async function () { await SpecialNewItemPage.open( { uselang: 'qqx' } ); const createNewItem = await SpecialNewItemPage.firstHeading.getText(); - assert.strictEqual( createNewItem, '(special-newitem)' ); + expect( createNewItem ).toBe( '(special-newitem)' ); } ); it( 'Should create an item on repo', async function () { diff --git a/test/specs/upgrade/pre-upgrade.ts b/test/specs/upgrade/pre-upgrade.ts index 323e99c3e..e93baef5a 100644 --- a/test/specs/upgrade/pre-upgrade.ts +++ b/test/specs/upgrade/pre-upgrade.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import { getTestString } from 'wdio-mediawiki/Util.js'; import WikibaseApi from 'wdio-wikibase/wikibase.api.js'; @@ -28,8 +27,8 @@ describe( 'Wikibase pre upgrade', function () { data ); - assert.strictEqual( itemId.startsWith( 'Q' ), true ); - assert.strictEqual( propertyId.startsWith( 'P' ), true ); + expect( itemId.startsWith( 'Q' ) ).toBe( true ); + expect( propertyId.startsWith( 'P' ) ).toBe( true ); } } ); @@ -53,7 +52,7 @@ describe( 'Wikibase pre upgrade', function () { const itemId = await WikibaseApi.createItem( itemLabel, data ); - assert.strictEqual( itemId.startsWith( 'Q' ), true ); - assert.strictEqual( propertyId.startsWith( 'P' ), true ); + expect( itemId.startsWith( 'Q' ) ).toBe( true ); + expect( propertyId.startsWith( 'P' ) ).toBe( true ); } ); } ); diff --git a/test/specs/upgrade/queryservice-post-upgrade.ts b/test/specs/upgrade/queryservice-post-upgrade.ts index 4ac385b68..143e2d719 100644 --- a/test/specs/upgrade/queryservice-post-upgrade.ts +++ b/test/specs/upgrade/queryservice-post-upgrade.ts @@ -39,8 +39,8 @@ describe( 'Wikibase post upgrade', function () { newItemId = await WikibaseApi.createItem( itemLabel, data ); - assert.strictEqual( newItemId.startsWith( 'Q' ), true ); - assert.strictEqual( newPropertyId.startsWith( 'P' ), true ); + expect( newItemId.startsWith( 'Q' ) ).toBe( true ); + expect( newPropertyId.startsWith( 'P' ) ).toBe( true ); } ); it( 'New item should show up in Queryservice', async function () { @@ -57,7 +57,7 @@ describe( 'Wikibase post upgrade', function () { } ); - assert.strictEqual( bindings.length, 9 ); + expect( bindings.length ).toBe( 9 ); const statement = getElementByURI( testEnv.vars.WIKIBASE_URL + '/prop/' + newPropertyId, @@ -100,7 +100,7 @@ describe( 'Wikibase post upgrade', function () { assert( timestamp !== null ); assert( statement !== null ); - assert.strictEqual( property.o.value, propertyValue ); - assert.strictEqual( itemLabelValue.o.value, itemLabel ); + expect( property.o.value ).toBe( propertyValue ); + expect( itemLabelValue.o.value ).toBe( itemLabel ); } ); } ); diff --git a/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts b/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts index 0e9bed453..f4a2bdccc 100644 --- a/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts +++ b/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts @@ -27,10 +27,10 @@ describe( 'Wikibase post upgrade', function () { const success = result.data.success; const searchResults = result.data.search; - assert.strictEqual( success, 1 ); - assert.strictEqual( searchResults.length, 1 ); - assert.strictEqual( searchResults[ 0 ].match.text, 'UpgradeItem' ); - assert.strictEqual( searchResults[ 0 ].match.type, 'label' ); + expect( success ).toBe( 1 ); + expect( searchResults.length ).toBe( 1 ); + expect( searchResults[ 0 ].match.text ).toBe( 'UpgradeItem' ); + expect( searchResults[ 0 ].match.type ).toBe( 'label' ); oldItemID = searchResults[ 0 ].id; @@ -41,7 +41,7 @@ describe( 'Wikibase post upgrade', function () { const data = await SpecialEntityDataPage.getData( oldItemID ); const properties = Object.keys( data.entities[ oldItemID ].claims ); - assert.strictEqual( properties.length, 1 ); + expect( properties.length ).toBe( 1 ); oldPropertyID = properties[ 0 ]; } ); @@ -61,7 +61,7 @@ describe( 'Wikibase post upgrade', function () { } ); - assert.strictEqual( bindings.length, 9 ); + expect( bindings.length ).toBe( 9 ); const statement = getElementByURI( `${ testEnv.vars.WIKIBASE_URL }/prop/${ oldPropertyID }`, @@ -106,9 +106,9 @@ describe( 'Wikibase post upgrade', function () { assert( statement !== null ); assert( property !== null ); - assert.strictEqual( property.o.value, 'UpgradeItemStringValue' ); + expect( property.o.value ).toBe( 'UpgradeItemStringValue' ); assert( itemLabelValue !== null ); - assert.strictEqual( itemLabelValue.o.value, 'UpgradeItem' ); + expect( itemLabelValue.o.value ).toBe( 'UpgradeItem' ); } ); } ); diff --git a/test/specs/upgrade/upgrade.ts b/test/specs/upgrade/upgrade.ts index 893343e02..34744ac16 100644 --- a/test/specs/upgrade/upgrade.ts +++ b/test/specs/upgrade/upgrade.ts @@ -65,8 +65,8 @@ describe( 'Wikibase upgrade', function () { getTestString( itemLabel ), data ); - assert.strictEqual( itemId.startsWith( 'Q' ), true ); - assert.strictEqual( propertyId.startsWith( 'P' ), true ); + expect( itemId.startsWith( 'Q' ) ).toBe( true ); + expect( propertyId.startsWith( 'P' ) ).toBe( true ); } } ); @@ -77,10 +77,10 @@ describe( 'Wikibase upgrade', function () { const success = result.data.success; const searchResults = result.data.search; - assert.strictEqual( success, 1 ); - assert.strictEqual( searchResults.length, 1 ); - assert.strictEqual( searchResults[ 0 ].match.text, 'UpgradeItem' ); - assert.strictEqual( searchResults[ 0 ].match.type, 'label' ); + expect( success ).toBe( 1 ); + expect( searchResults.length ).toBe( 1 ); + expect( searchResults[ 0 ].match.text ).toBe( 'UpgradeItem' ); + expect( searchResults[ 0 ].match.type ).toBe( 'label' ); oldItemID = searchResults[ 0 ].id; From a74a3d926bd265d2b99727e51b37474a9f99b68e Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 01:25:45 +0100 Subject: [PATCH 02/26] assert.equal --- test/specs/fedprops/item.ts | 4 ++-- test/specs/repo_client/item.ts | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/test/specs/fedprops/item.ts b/test/specs/fedprops/item.ts index c233c9265..34e853f35 100644 --- a/test/specs/fedprops/item.ts +++ b/test/specs/fedprops/item.ts @@ -55,7 +55,7 @@ describe( 'Fed props Item', function () { await SpecialEntityDataPage.getData( 'Q1', 'ttl' ); } catch ( error ) { assert( error instanceof AxiosError ); - assert.equal( error.request.res.statusCode, 500 ); + expect( error.request.res.statusCode ).toBe( 500 ); } } ); @@ -72,7 +72,7 @@ describe( 'Fed props Item', function () { await SpecialEntityDataPage.getData( 'Q1', 'rdf' ); } catch ( error ) { assert( error instanceof AxiosError ); - assert.equal( error.request.res.statusCode, 500 ); + expect( error.request.res.statusCode ).toBe( 500 ); } } ); diff --git a/test/specs/repo_client/item.ts b/test/specs/repo_client/item.ts index ad5fa1f5d..efbe55dbf 100644 --- a/test/specs/repo_client/item.ts +++ b/test/specs/repo_client/item.ts @@ -67,7 +67,7 @@ describe( 'Item', function () { `{{#statements:${ propertyId }|from=${ itemId }}}` ); // label should come from repo property - assert.equal( bodyText, propertyValue ); + expect( bodyText ).toBe( propertyValue ); assert( bodyText.includes( propertyValue ) ); } ); From e20d609053b2d5fcd1c2262d985c9dc9280f7e7c Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 01:30:19 +0100 Subject: [PATCH 03/26] Expect Inequality --- test/specs/fedprops/item.ts | 2 +- test/specs/repo/extensions/scribunto.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/test/specs/fedprops/item.ts b/test/specs/fedprops/item.ts index 34e853f35..455181188 100644 --- a/test/specs/fedprops/item.ts +++ b/test/specs/fedprops/item.ts @@ -21,7 +21,7 @@ describe( 'Fed props Item', function () { const searchResults = result.data.search; expect( success ).toBe( 1 ); - assert( searchResults.length > 0 ); + expect( searchResults.length ).toBeGreaterThan( 0 ); } ); it( 'can add a federated property and it shows up in the ui', async function () { diff --git a/test/specs/repo/extensions/scribunto.ts b/test/specs/repo/extensions/scribunto.ts index 439a2fd35..99ee61e67 100644 --- a/test/specs/repo/extensions/scribunto.ts +++ b/test/specs/repo/extensions/scribunto.ts @@ -35,7 +35,7 @@ describe( 'Scribunto', function () { 'LuaTest' ); - assert( cpuTime.value < 0.05 ); + expect( cpuTime.value ).toBeLessThan( 0.05 ); expect( cpuTime.scale ).toBe( 'seconds' ); } ); } ); From 896b161133564951f0ecadb886ba3fb57c5b30a4 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 01:33:18 +0100 Subject: [PATCH 04/26] toHaveLength --- test/specs/fedprops/prefetching.ts | 8 ++++---- test/specs/pingback/pingback.ts | 2 +- test/specs/repo/property.ts | 12 ++++++------ test/specs/upgrade/queryservice-post-upgrade.ts | 2 +- .../upgrade/queryservice-pre-and-post-upgrade.ts | 6 +++--- test/specs/upgrade/upgrade.ts | 2 +- 6 files changed, 16 insertions(+), 16 deletions(-) diff --git a/test/specs/fedprops/prefetching.ts b/test/specs/fedprops/prefetching.ts index 0fc882065..bc347a1d7 100644 --- a/test/specs/fedprops/prefetching.ts +++ b/test/specs/fedprops/prefetching.ts @@ -33,7 +33,7 @@ describe( 'Property Prefetching', function () { }; } ) ); - expect( claims.length ).toBe( NUM_PROPERTIES ); + expect( claims ).toHaveLength( NUM_PROPERTIES ); const data = { claims: claims }; itemId = await WikibaseApi.createItem( getTestString( itemLabel ), data ); @@ -50,7 +50,7 @@ describe( 'Property Prefetching', function () { statements.map( async ( statement ) => statement.getAttribute( 'id' ) ) ); - expect( propertyGuids.length ).toBe( NUM_PROPERTIES ); + expect( propertyGuids ).toHaveLength( NUM_PROPERTIES ); for ( const guid of propertyGuids ) { const response = await browser.deleteClaim( guid ); @@ -67,7 +67,7 @@ describe( 'Property Prefetching', function () { await $( '#pagehistory' ); // +1 for the initial item creation - expect( ( await $$( '#pagehistory li' ) ).length ).toBe( NUM_PROPERTIES + 1 ); + expect( await $$( '#pagehistory li' ) ).toHaveLength( NUM_PROPERTIES + 1 ); } ); it( 'Should render recent changes list within threshold', async function () { @@ -79,6 +79,6 @@ describe( 'Property Prefetching', function () { // +1 for the initial item creation // +1 for the Main Page creation? // +1 for ? - expect( ( await $$( 'ul.special li' ) ).length ).toBe( NUM_PROPERTIES + 3 ); + expect( await $$( 'ul.special li' ) ).toHaveLength( NUM_PROPERTIES + 3 ); } ); } ); diff --git a/test/specs/pingback/pingback.ts b/test/specs/pingback/pingback.ts index 4a4b949fe..4fafe1a7d 100644 --- a/test/specs/pingback/pingback.ts +++ b/test/specs/pingback/pingback.ts @@ -12,7 +12,7 @@ describe( 'Pingback', function () { expect( sqlResult.includes( 'WikibasePingback-1.' ) ).toBe( true ); const result = await browser.makeRequest( 'http://mediawiki.svc' ); - expect( result.data.length ).toBe( 2 ); + expect( result.data ).toHaveLength( 2 ); const requestData = JSON.parse( Object.keys( result.data[ 0 ] )[ 0 ].replace( ';', '' ) diff --git a/test/specs/repo/property.ts b/test/specs/repo/property.ts index eeb9ff144..be885cbcc 100644 --- a/test/specs/repo/property.ts +++ b/test/specs/repo/property.ts @@ -96,9 +96,9 @@ describe( 'Property', function () { it( 'Should be able to revert a change', async function () { await $( '=View history' ).click(); - await expect( - ( await $( 'ul.mw-contributions-list' ).$$( 'li' ) ).length - ).toBe( 3 ); + await expect( await $( 'ul.mw-contributions-list' ).$$( 'li' ) ).toHaveLength( + 3 + ); await $( 'ul.mw-contributions-list' ).$( 'li.before' ).$( 'a=undo' ).click(); await $( 'label=Summary (will be appended to an automatically generated summary):' @@ -107,9 +107,9 @@ describe( 'Property', function () { await $( 'button=Save page' ).click(); await $( '=View history' ).click(); - await expect( - ( await $( 'ul.mw-contributions-list' ).$$( 'li' ) ).length - ).toBe( 4 ); + await expect( await $( 'ul.mw-contributions-list' ).$$( 'li' ) ).toHaveLength( + 4 + ); await expect( $( 'span.mw-tag-marker-mw-undo' ) ).toExist(); await expect( $( 'ul.mw-contributions-list' ).$( 'li.before' ) diff --git a/test/specs/upgrade/queryservice-post-upgrade.ts b/test/specs/upgrade/queryservice-post-upgrade.ts index 143e2d719..276d288f4 100644 --- a/test/specs/upgrade/queryservice-post-upgrade.ts +++ b/test/specs/upgrade/queryservice-post-upgrade.ts @@ -57,7 +57,7 @@ describe( 'Wikibase post upgrade', function () { } ); - expect( bindings.length ).toBe( 9 ); + expect( bindings ).toHaveLength( 9 ); const statement = getElementByURI( testEnv.vars.WIKIBASE_URL + '/prop/' + newPropertyId, diff --git a/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts b/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts index f4a2bdccc..b378d492d 100644 --- a/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts +++ b/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts @@ -28,7 +28,7 @@ describe( 'Wikibase post upgrade', function () { const searchResults = result.data.search; expect( success ).toBe( 1 ); - expect( searchResults.length ).toBe( 1 ); + expect( searchResults ).toHaveLength( 1 ); expect( searchResults[ 0 ].match.text ).toBe( 'UpgradeItem' ); expect( searchResults[ 0 ].match.type ).toBe( 'label' ); @@ -41,7 +41,7 @@ describe( 'Wikibase post upgrade', function () { const data = await SpecialEntityDataPage.getData( oldItemID ); const properties = Object.keys( data.entities[ oldItemID ].claims ); - expect( properties.length ).toBe( 1 ); + expect( properties ).toHaveLength( 1 ); oldPropertyID = properties[ 0 ]; } ); @@ -61,7 +61,7 @@ describe( 'Wikibase post upgrade', function () { } ); - expect( bindings.length ).toBe( 9 ); + expect( bindings ).toHaveLength( 9 ); const statement = getElementByURI( `${ testEnv.vars.WIKIBASE_URL }/prop/${ oldPropertyID }`, diff --git a/test/specs/upgrade/upgrade.ts b/test/specs/upgrade/upgrade.ts index 34744ac16..ab60c3fe9 100644 --- a/test/specs/upgrade/upgrade.ts +++ b/test/specs/upgrade/upgrade.ts @@ -78,7 +78,7 @@ describe( 'Wikibase upgrade', function () { const searchResults = result.data.search; expect( success ).toBe( 1 ); - expect( searchResults.length ).toBe( 1 ); + expect( searchResults ).toHaveLength( 1 ); expect( searchResults[ 0 ].match.text ).toBe( 'UpgradeItem' ); expect( searchResults[ 0 ].match.type ).toBe( 'label' ); From dabb18b078a3c10f4d31ce36c57e3d590d9966ac Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 01:45:12 +0100 Subject: [PATCH 05/26] .not.toBeNull --- test/specs/repo/special-version.ts | 4 +--- test/specs/upgrade/queryservice-post-upgrade.ts | 13 ++++++------- test/specs/upgrade/upgrade.ts | 3 +-- 3 files changed, 8 insertions(+), 12 deletions(-) diff --git a/test/specs/repo/special-version.ts b/test/specs/repo/special-version.ts index a2e6913aa..65110a75f 100644 --- a/test/specs/repo/special-version.ts +++ b/test/specs/repo/special-version.ts @@ -1,5 +1,3 @@ -import assert from 'assert'; - describe( 'Special:Version', function () { it( 'Should contain the correct MediaWiki version', async function () { await browser.url( `${ testEnv.vars.WIKIBASE_URL }/wiki/Special:Version` ); @@ -49,7 +47,7 @@ describe( 'Special:Version', function () { ); await elementSelector.scrollIntoView(); - assert( elementSelector.getText() !== null ); + expect( await elementSelector.getText() ).not.toBeNull(); } ); } ); } ); diff --git a/test/specs/upgrade/queryservice-post-upgrade.ts b/test/specs/upgrade/queryservice-post-upgrade.ts index 276d288f4..c329973cf 100644 --- a/test/specs/upgrade/queryservice-post-upgrade.ts +++ b/test/specs/upgrade/queryservice-post-upgrade.ts @@ -4,7 +4,6 @@ for unknown reasons. This spec existed but was skipped in the code the Wikibase team inherited. */ -import assert from 'assert'; import WikibaseApi from 'wdio-wikibase/wikibase.api.js'; import { getElementByURI } from '../../helpers/blazegraph.js'; import Binding from '../../types/binding.js'; @@ -93,12 +92,12 @@ describe( 'Wikibase post upgrade', function () { bindings ); - assert( dateModified !== null ); - assert( schemaVersion !== null ); - assert( siteLinks !== null ); - assert( identifiers !== null ); - assert( timestamp !== null ); - assert( statement !== null ); + expect( dateModified ).not.toBeNull(); + expect( schemaVersion ).not.toBeNull(); + expect( siteLinks ).not.toBeNull(); + expect( identifiers ).not.toBeNull(); + expect( timestamp ).not.toBeNull(); + expect( statement ).not.toBeNull(); expect( property.o.value ).toBe( propertyValue ); expect( itemLabelValue.o.value ).toBe( itemLabel ); diff --git a/test/specs/upgrade/upgrade.ts b/test/specs/upgrade/upgrade.ts index ab60c3fe9..a37c53302 100644 --- a/test/specs/upgrade/upgrade.ts +++ b/test/specs/upgrade/upgrade.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import { spawnSync } from 'child_process'; import { getTestString } from 'wdio-mediawiki/Util.js'; import WikibaseApi from 'wdio-wikibase/wikibase.api.js'; @@ -89,6 +88,6 @@ describe( 'Wikibase upgrade', function () { it( 'should show up in Special:EntityData with json', async function () { const data = await SpecialEntityDataPage.getData( oldItemID ); - assert( data.entities[ oldItemID ].claims[ 0 ] !== null ); + expect( data.entities[ oldItemID ].claims[ 0 ] ).not.toBeNull(); } ); } ); From ee5cb113249097ace6e0508cc6d61e8ebb0cc560 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 01:54:23 +0100 Subject: [PATCH 06/26] toHaveText - simple --- test/specs/fedprops/item.ts | 7 ++-- .../extensions/universal-language-selector.ts | 4 +-- test/specs/repo/extensions/visual-editor.ts | 4 +-- test/specs/repo/special-item.ts | 34 ++++++++----------- test/specs/repo/special-version.ts | 7 ++-- test/specs/repo_client/item.ts | 22 ++++++------ 6 files changed, 35 insertions(+), 43 deletions(-) diff --git a/test/specs/fedprops/item.ts b/test/specs/fedprops/item.ts index 455181188..e247e6b9f 100644 --- a/test/specs/fedprops/item.ts +++ b/test/specs/fedprops/item.ts @@ -42,10 +42,9 @@ describe( 'Fed props Item', function () { await ItemPage.open( itemId ); - const actualPropertyValue = await $( - '.wikibase-statementgroupview-property' - ).getText(); - assert( actualPropertyValue.includes( propertyValue ) ); // value is the label + await expect( + $( '.wikibase-statementgroupview-property' ) + ).toHaveTextContaining( propertyValue ); // value is the label await SpecialEntityPage.addStatementLink; } ); diff --git a/test/specs/repo/extensions/universal-language-selector.ts b/test/specs/repo/extensions/universal-language-selector.ts index 2d051a7c2..cc9530325 100644 --- a/test/specs/repo/extensions/universal-language-selector.ts +++ b/test/specs/repo/extensions/universal-language-selector.ts @@ -8,8 +8,6 @@ describe( 'UniversalLanguageSelector', function () { await $( '#searchInput' ).click(); await $( '.imeselector' ).click(); - const firstLang = await $( '.imeselector-menu h3' ).getText(); - - expect( firstLang ).toBe( 'English' ); + await expect( $( '.imeselector-menu h3' ) ).toHaveText( 'English' ); } ); } ); diff --git a/test/specs/repo/extensions/visual-editor.ts b/test/specs/repo/extensions/visual-editor.ts index f61a4f8a2..d3155235b 100644 --- a/test/specs/repo/extensions/visual-editor.ts +++ b/test/specs/repo/extensions/visual-editor.ts @@ -31,8 +31,6 @@ describe( 'VisualEditor', function () { await $( '.oo-ui-processDialog-actions-primary a' ).click(); - const contentBody = await $( '.mw-parser-output' ).getText(); - - expect( contentBody ).toBe( 'TEST' ); + await expect( $( '.mw-parser-output' ) ).toHaveText( 'TEST' ); } ); } ); diff --git a/test/specs/repo/special-item.ts b/test/specs/repo/special-item.ts index 02b992b4d..d1e4ca57a 100644 --- a/test/specs/repo/special-item.ts +++ b/test/specs/repo/special-item.ts @@ -17,24 +17,20 @@ describe( 'Special:NewItem', function () { await SpecialEntityPage.addStatementLink; - const labelText = await $( - '.wikibase-entitytermsforlanguageview-label' - ).getText(); - expect( labelText ).toBe( label ); - - const descriptionText = await $( - '.wikibase-entitytermsforlanguageview-description' - ).getText(); - expect( descriptionText ).toBe( description ); - - const firstAliasText = await $( - '.wikibase-entitytermsforlanguageview-aliases li:nth-child(1)' - ).getText(); - expect( firstAliasText ).toBe( firstAlias ); - - const secondAliasText = await $( - '.wikibase-entitytermsforlanguageview-aliases li:nth-child(2)' - ).getText(); - expect( secondAliasText ).toBe( secondAlias ); + await expect( $( '.wikibase-entitytermsforlanguageview-label' ) ).toHaveText( + label + ); + + await expect( + $( '.wikibase-entitytermsforlanguageview-description' ) + ).toHaveText( description ); + + await expect( + $( '.wikibase-entitytermsforlanguageview-aliases li:nth-child(1)' ) + ).toHaveText( firstAlias ); + + await expect( + $( '.wikibase-entitytermsforlanguageview-aliases li:nth-child(2)' ) + ).toHaveText( secondAlias ); } ); } ); diff --git a/test/specs/repo/special-version.ts b/test/specs/repo/special-version.ts index 65110a75f..4ac33c103 100644 --- a/test/specs/repo/special-version.ts +++ b/test/specs/repo/special-version.ts @@ -1,9 +1,8 @@ describe( 'Special:Version', function () { it( 'Should contain the correct MediaWiki version', async function () { await browser.url( `${ testEnv.vars.WIKIBASE_URL }/wiki/Special:Version` ); - const text = await $( '#sv-software' ).getText(); - expect( text.includes( `MediaWiki ${ testEnv.vars.MEDIAWIKI_VERSION }` ) ).toBe( - true + await expect( $( '#sv-software' ) ).toHaveTextContaining( + `MediaWiki ${ testEnv.vars.MEDIAWIKI_VERSION }` ); } ); @@ -47,7 +46,7 @@ describe( 'Special:Version', function () { ); await elementSelector.scrollIntoView(); - expect( await elementSelector.getText() ).not.toBeNull(); + await expect( elementSelector ).toHaveText( /.+/ ); } ); } ); } ); diff --git a/test/specs/repo_client/item.ts b/test/specs/repo_client/item.ts index efbe55dbf..a30a6ccd8 100644 --- a/test/specs/repo_client/item.ts +++ b/test/specs/repo_client/item.ts @@ -25,14 +25,16 @@ describe( 'Item', function () { await browser.url( `${ testEnv.vars.WIKIBASE_CLIENT_URL }/wiki/Special:NewItem?uselang=qqx` ); - const notFoundText = await SpecialNewItemPage.firstHeading.getText(); - expect( notFoundText ).toBe( '(nosuchspecialpage)' ); + await expect( SpecialNewItemPage.firstHeading ).toHaveText( + '(nosuchspecialpage)' + ); } ); it( 'Special:NewItem should be visible on repo', async function () { await SpecialNewItemPage.open( { uselang: 'qqx' } ); - const createNewItem = await SpecialNewItemPage.firstHeading.getText(); - expect( createNewItem ).toBe( '(special-newitem)' ); + await expect( SpecialNewItemPage.firstHeading ).toHaveText( + '(special-newitem)' + ); } ); it( 'Should create an item on repo', async function () { @@ -79,13 +81,13 @@ describe( 'Item', function () { ); await $( '#wb-setsitelink-submit button' ).click(); - const siteLinkValue = await $( - '.wikibase-sitelinklistview-listview li' - ).getText(); - // label should come from repo property - assert( siteLinkValue.includes( 'client_wiki' ) ); - assert( siteLinkValue.includes( pageTitle ) ); + await expect( + $( '.wikibase-sitelinklistview-listview li' ) + ).toHaveTextContaining( 'client_wiki' ); + await expect( + $( '.wikibase-sitelinklistview-listview li' ) + ).toHaveTextContaining( pageTitle ); } ); it( 'Should be able to see site-link change is dispatched to client', async function () { From de3dfd9b9d13cd0290afb51c340bc3381ea0ff98 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 02:04:17 +0100 Subject: [PATCH 07/26] toBeInstanceOf --- test/specs/fedprops/item.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/test/specs/fedprops/item.ts b/test/specs/fedprops/item.ts index e247e6b9f..8ef99298b 100644 --- a/test/specs/fedprops/item.ts +++ b/test/specs/fedprops/item.ts @@ -53,7 +53,7 @@ describe( 'Fed props Item', function () { try { await SpecialEntityDataPage.getData( 'Q1', 'ttl' ); } catch ( error ) { - assert( error instanceof AxiosError ); + expect( error ).toBeInstanceOf( AxiosError ); expect( error.request.res.statusCode ).toBe( 500 ); } } ); @@ -70,7 +70,7 @@ describe( 'Fed props Item', function () { try { await SpecialEntityDataPage.getData( 'Q1', 'rdf' ); } catch ( error ) { - assert( error instanceof AxiosError ); + expect( error ).toBeInstanceOf( AxiosError ); expect( error.request.res.statusCode ).toBe( 500 ); } } ); From 864a941cc04fb5c9488c412c07e87d7df524fbe9 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 02:04:38 +0100 Subject: [PATCH 08/26] not.toBeNull --- .../queryservice-pre-and-post-upgrade.ts | 17 ++++++++--------- 1 file changed, 8 insertions(+), 9 deletions(-) diff --git a/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts b/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts index b378d492d..882c2d0cb 100644 --- a/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts +++ b/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts @@ -4,7 +4,6 @@ for unknown reasons. This spec existed but was skipped in the code the Wikibase team inherited. */ -import assert from 'assert'; import { getElementByURI } from '../../helpers/blazegraph.js'; import ItemPage from '../../helpers/pages/entity/item.page.js'; import SpecialEntityDataPage from '../../helpers/pages/special/entity-data.page.js'; @@ -98,17 +97,17 @@ describe( 'Wikibase post upgrade', function () { bindings ); - assert( dateModified !== null ); - assert( schemaVersion !== null ); - assert( siteLinks !== null ); - assert( identifiers !== null ); - assert( timestamp !== null ); - assert( statement !== null ); + expect( dateModified ).not.toBeNull(); + expect( schemaVersion ).not.toBeNull(); + expect( siteLinks ).not.toBeNull(); + expect( identifiers ).not.toBeNull(); + expect( timestamp ).not.toBeNull(); + expect( statement ).not.toBeNull(); - assert( property !== null ); + expect( property ).not.toBeNull(); expect( property.o.value ).toBe( 'UpgradeItemStringValue' ); - assert( itemLabelValue !== null ); + expect( itemLabelValue ).not.toBeNull(); expect( itemLabelValue.o.value ).toBe( 'UpgradeItem' ); } ); } ); From ff9ca4d3c0dff02f31857da0e4cbdc2ed89eb985 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 02:14:32 +0100 Subject: [PATCH 09/26] assert(value) --- test/specs/fedprops/item.ts | 44 ++++++++++------- test/specs/quickstatements/quickstatements.ts | 8 +-- test/specs/repo/extensions/entityschema.ts | 2 +- test/specs/repo/extensions/scribunto.ts | 3 +- test/specs/repo/queryservice.ts | 49 ++++++++++++------- .../repo_client/extensions/scribunto-item.ts | 2 +- test/specs/repo_client/interwiki-links.ts | 7 +-- test/specs/repo_client/item.ts | 2 +- 8 files changed, 68 insertions(+), 49 deletions(-) diff --git a/test/specs/fedprops/item.ts b/test/specs/fedprops/item.ts index 8ef99298b..6141fd633 100644 --- a/test/specs/fedprops/item.ts +++ b/test/specs/fedprops/item.ts @@ -89,12 +89,12 @@ describe( 'Fed props Item', function () { await QueryServiceUIPage.resultTable; // Item should never have made its way into the query service, as TTL doesnt work - assert( - !( await QueryServiceUIPage.resultIncludes( + expect( + await QueryServiceUIPage.resultIncludes( `<${ testEnv.vars.WIKIBASE_URL }/entity/${ itemId }>`, propertyValue - ) ) - ); + ) + ).toBe( false ); } ); it( 'should NOT show up in queryservice ui after creation', async function () { @@ -105,23 +105,31 @@ describe( 'Fed props Item', function () { await QueryServiceUIPage.resultTable; // Item should never have made its way into the query service, as TTL doesnt work - assert( !( await QueryServiceUIPage.resultIncludes( 'schema:version' ) ) ); - assert( !( await QueryServiceUIPage.resultIncludes( 'schema:dateModified' ) ) ); - assert( !( await QueryServiceUIPage.resultIncludes( 'wikibase:timestamp' ) ) ); - - assert( !( await QueryServiceUIPage.resultIncludes( 'rdfs:label', itemLabel ) ) ); - - assert( - !( await QueryServiceUIPage.resultIncludes( 'wikibase:statements', '1' ) ) + expect( await QueryServiceUIPage.resultIncludes( 'schema:version' ) ).toBe( + false ); - - assert( - !( await QueryServiceUIPage.resultIncludes( 'wikibase:sitelinks', '0' ) ) + expect( await QueryServiceUIPage.resultIncludes( 'schema:dateModified' ) ).toBe( + false ); - assert( - !( await QueryServiceUIPage.resultIncludes( 'wikibase:identifiers', '1' ) ) + expect( await QueryServiceUIPage.resultIncludes( 'wikibase:timestamp' ) ).toBe( + false ); - assert( !( await QueryServiceUIPage.resultIncludes( 'p:P213' ) ) ); + expect( + await QueryServiceUIPage.resultIncludes( 'rdfs:label', itemLabel ) + ).toBe( false ); + + expect( + await QueryServiceUIPage.resultIncludes( 'wikibase:statements', '1' ) + ).toBe( false ); + + expect( + await QueryServiceUIPage.resultIncludes( 'wikibase:sitelinks', '0' ) + ).toBe( false ); + expect( + await QueryServiceUIPage.resultIncludes( 'wikibase:identifiers', '1' ) + ).toBe( false ); + + expect( await QueryServiceUIPage.resultIncludes( 'p:P213' ) ).toBe( false ); } ); } ); diff --git a/test/specs/quickstatements/quickstatements.ts b/test/specs/quickstatements/quickstatements.ts index c7e864938..e15937064 100644 --- a/test/specs/quickstatements/quickstatements.ts +++ b/test/specs/quickstatements/quickstatements.ts @@ -143,7 +143,7 @@ describe( 'QuickStatements Service', function () { // go look at wikibase const responseQ1Data = await SpecialEntityDataPage.getData( 'Q1' ); - assert( lodash.isEmpty( responseQ1Data.entities.Q1.aliases ) !== true ); + expect( lodash.isEmpty( responseQ1Data.entities.Q1.aliases ) ).toBe( false ); } ); it( 'Should be able to add a label to an item', async function () { @@ -152,7 +152,7 @@ describe( 'QuickStatements Service', function () { // go look at wikibase const responseQ1Data = await SpecialEntityDataPage.getData( 'Q1' ); - assert( lodash.isEmpty( responseQ1Data.entities.Q1.labels ) !== true ); + expect( lodash.isEmpty( responseQ1Data.entities.Q1.labels ) ).toBe( false ); } ); it( 'Should be able to add a description to an item', async function () { @@ -161,7 +161,7 @@ describe( 'QuickStatements Service', function () { // go look at wikibase const responseQ1Data = await SpecialEntityDataPage.getData( 'Q1' ); - assert( lodash.isEmpty( responseQ1Data.entities.Q1.descriptions ) !== true ); + expect( lodash.isEmpty( responseQ1Data.entities.Q1.descriptions ) ).toBe( false ); } ); it.skip( 'Should be able to add a sitelink to an item', async function () { @@ -170,7 +170,7 @@ describe( 'QuickStatements Service', function () { // go look at wikibase const responseQ1Data = await SpecialEntityDataPage.getData( 'Q1' ); - assert( lodash.isEmpty( responseQ1Data.entities.Q1.sitelinks ) !== true ); + expect( lodash.isEmpty( responseQ1Data.entities.Q1.sitelinks ) ).toBe( false ); } ); it( 'Should be able to add a statement to an item', async function () { diff --git a/test/specs/repo/extensions/entityschema.ts b/test/specs/repo/extensions/entityschema.ts index df7b99f56..1717209d2 100644 --- a/test/specs/repo/extensions/entityschema.ts +++ b/test/specs/repo/extensions/entityschema.ts @@ -54,6 +54,6 @@ describe( 'EntitySchema', function () { 'href' ); - assert( linkUrl.includes( 'http://validator.svc' ) ); + expect( linkUrl.includes( 'http://validator.svc' ) ).toBe( true ); } ); } ); diff --git a/test/specs/repo/extensions/scribunto.ts b/test/specs/repo/extensions/scribunto.ts index 99ee61e67..467e8e93e 100644 --- a/test/specs/repo/extensions/scribunto.ts +++ b/test/specs/repo/extensions/scribunto.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import { readFile } from 'fs/promises'; import { utf8 } from '../../../helpers/readFileEncoding.js'; @@ -26,7 +25,7 @@ describe( 'Scribunto', function () { ); // should come from executed lua script - assert( executionContent.includes( 'Hello, world!' ) ); + expect( executionContent.includes( 'Hello, world!' ) ).toBe( true ); } ); it( 'Should be able to execute lua module within 0.05 seconds', async function () { diff --git a/test/specs/repo/queryservice.ts b/test/specs/repo/queryservice.ts index 0940ea5ea..ebe0518bb 100644 --- a/test/specs/repo/queryservice.ts +++ b/test/specs/repo/queryservice.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import { stringify } from 'querystring'; import LoginPage from 'wdio-mediawiki/LoginPage.js'; import { getTestString } from 'wdio-mediawiki/Util.js'; @@ -78,28 +77,40 @@ describe( 'QueryService', function () { await QueryServiceUIPage.submit(); await QueryServiceUIPage.resultTable; - assert( await QueryServiceUIPage.resultIncludes( 'schema:version' ) ); - assert( await QueryServiceUIPage.resultIncludes( 'schema:dateModified' ) ); - assert( await QueryServiceUIPage.resultIncludes( 'wikibase:timestamp' ) ); + expect( await QueryServiceUIPage.resultIncludes( 'schema:version' ) ).toBe( + true + ); + expect( await QueryServiceUIPage.resultIncludes( 'schema:dateModified' ) ).toBe( + true + ); + expect( await QueryServiceUIPage.resultIncludes( 'wikibase:timestamp' ) ).toBe( + true + ); // label should match on the prefix - assert( await QueryServiceUIPage.resultIncludes( 'rdfs:label', itemLabel ) ); + expect( + await QueryServiceUIPage.resultIncludes( 'rdfs:label', itemLabel ) + ).toBe( true ); // should have one statement - assert( await QueryServiceUIPage.resultIncludes( 'wikibase:statements', '1' ) ); + expect( + await QueryServiceUIPage.resultIncludes( 'wikibase:statements', '1' ) + ).toBe( true ); - assert( await QueryServiceUIPage.resultIncludes( 'wikibase:sitelinks', '0' ) ); - assert( + expect( + await QueryServiceUIPage.resultIncludes( 'wikibase:sitelinks', '0' ) + ).toBe( true ); + expect( await QueryServiceUIPage.resultIncludes( 'wikibase:identifiers', '0' ) - ); + ).toBe( true ); // property value is set with correct rdf - assert( + expect( await QueryServiceUIPage.resultIncludes( `<${ testEnv.vars.WIKIBASE_URL }/prop/direct/${ propertyId }>`, propertyValue ) - ); + ).toBe( true ); // query the property using wdt: prefix await QueryServiceUIPage.open( `SELECT * WHERE{ ?s wdt:${ propertyId } ?o }` ); @@ -108,12 +119,12 @@ describe( 'QueryService', function () { await QueryServiceUIPage.resultTable; // should be set only to the item - assert( + expect( await QueryServiceUIPage.resultIncludes( `<${ testEnv.vars.WIKIBASE_URL }/entity/${ itemId }>`, propertyValue ) - ); + ).toBe( true ); } ); it( 'Should not show up in queryservice ui after deletion', async function () { @@ -143,14 +154,14 @@ describe( 'QueryService', function () { const resultText = await QueryServiceUIPage.resultTable.getText(); // item should not be included - assert( !resultText.includes( 'schema:version' ) ); - assert( !resultText.includes( 'schema:dateModified' ) ); - assert( !resultText.includes( 'wikibase:sitelinks' ) ); - assert( !resultText.includes( 'wikibase:identifiers' ) ); - assert( !resultText.includes( 'rdfs:label' ) ); + expect( !resultText.includes( 'schema:version' ) ).toBe( true ); + expect( !resultText.includes( 'schema:dateModified' ) ).toBe( true ); + expect( !resultText.includes( 'wikibase:sitelinks' ) ).toBe( true ); + expect( !resultText.includes( 'wikibase:identifiers' ) ).toBe( true ); + expect( !resultText.includes( 'rdfs:label' ) ).toBe( true ); // timestamp always shows - assert( resultText.includes( 'wikibase:timestamp' ) ); + expect( resultText.includes( 'wikibase:timestamp' ) ).toBe( true ); } ); it( 'Should show results for a select query', async function () { diff --git a/test/specs/repo_client/extensions/scribunto-item.ts b/test/specs/repo_client/extensions/scribunto-item.ts index 61392523d..95ca1ce68 100644 --- a/test/specs/repo_client/extensions/scribunto-item.ts +++ b/test/specs/repo_client/extensions/scribunto-item.ts @@ -67,7 +67,7 @@ describe( 'Scribunto Item', function () { ); // should come from executed lua script - assert( executionContent.includes( itemLabel ) ); + expect( executionContent.includes( itemLabel ) ).toBe( true ); } ); // This will generate a change that will dispatch diff --git a/test/specs/repo_client/interwiki-links.ts b/test/specs/repo_client/interwiki-links.ts index 1872c3ac1..dfddd0e43 100644 --- a/test/specs/repo_client/interwiki-links.ts +++ b/test/specs/repo_client/interwiki-links.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import { readFile } from 'fs/promises'; import { utf8 } from '../../helpers/readFileEncoding.js'; @@ -17,7 +16,9 @@ describe( 'Interwiki links', function () { const clientWikiQueryResults = await browser.dbQuery( 'SELECT iw_url FROM interwiki WHERE iw_prefix = "client_wiki"' ); - assert( clientWikiQueryResults.includes( testEnv.vars.WIKIBASE_CLIENT_URL ) ); + expect( + clientWikiQueryResults.includes( testEnv.vars.WIKIBASE_CLIENT_URL ) + ).toBe( true ); const config = { user: testEnv.vars.DB_USER, @@ -34,6 +35,6 @@ describe( 'Interwiki links', function () { 'SELECT iw_url FROM interwiki WHERE iw_prefix = "my_wiki"', config ); - assert( myWikiQueryResults.includes( testEnv.vars.WIKIBASE_URL ) ); + expect( myWikiQueryResults.includes( testEnv.vars.WIKIBASE_URL ) ).toBe( true ); } ); } ); diff --git a/test/specs/repo_client/item.ts b/test/specs/repo_client/item.ts index a30a6ccd8..936e9b2dc 100644 --- a/test/specs/repo_client/item.ts +++ b/test/specs/repo_client/item.ts @@ -70,7 +70,7 @@ describe( 'Item', function () { ); // label should come from repo property expect( bodyText ).toBe( propertyValue ); - assert( bodyText.includes( propertyValue ) ); + expect( bodyText.includes( propertyValue ) ).toBe( true ); } ); // This will generate a change that will dispatch From 897b1c284e1f383a2f7f020da000b88431c57861 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 02:16:21 +0100 Subject: [PATCH 10/26] false --- test/specs/repo/queryservice.ts | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/test/specs/repo/queryservice.ts b/test/specs/repo/queryservice.ts index ebe0518bb..e4c8aa5db 100644 --- a/test/specs/repo/queryservice.ts +++ b/test/specs/repo/queryservice.ts @@ -154,11 +154,11 @@ describe( 'QueryService', function () { const resultText = await QueryServiceUIPage.resultTable.getText(); // item should not be included - expect( !resultText.includes( 'schema:version' ) ).toBe( true ); - expect( !resultText.includes( 'schema:dateModified' ) ).toBe( true ); - expect( !resultText.includes( 'wikibase:sitelinks' ) ).toBe( true ); - expect( !resultText.includes( 'wikibase:identifiers' ) ).toBe( true ); - expect( !resultText.includes( 'rdfs:label' ) ).toBe( true ); + expect( resultText.includes( 'schema:version' ) ).toBe( false ); + expect( resultText.includes( 'schema:dateModified' ) ).toBe( false ); + expect( resultText.includes( 'wikibase:sitelinks' ) ).toBe( false ); + expect( resultText.includes( 'wikibase:identifiers' ) ).toBe( false ); + expect( resultText.includes( 'rdfs:label' ) ).toBe( false ); // timestamp always shows expect( resultText.includes( 'wikibase:timestamp' ) ).toBe( true ); From 780108e594341b0ba6fb0fc23f78742eaa5d69fa Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 11:11:09 +0100 Subject: [PATCH 11/26] .not.toBeNull --- test/specs/fedprops/item.ts | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/test/specs/fedprops/item.ts b/test/specs/fedprops/item.ts index 6141fd633..0186acddc 100644 --- a/test/specs/fedprops/item.ts +++ b/test/specs/fedprops/item.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import { AxiosError } from 'axios'; import { getTestString } from 'wdio-mediawiki/Util.js'; import SpecialEntityPage from 'wdio-wikibase/pageobjects/item.page.js'; @@ -60,10 +59,9 @@ describe( 'Fed props Item', function () { it( 'should show up in Special:EntityData with json', async function () { const data = await SpecialEntityDataPage.getData( 'Q1' ); - assert.notEqual( - data.entities.Q1.claims[ 'http://www.wikidata.org/entity/P213' ], - null - ); + expect( + data.entities.Q1.claims[ 'http://www.wikidata.org/entity/P213' ] + ).not.toBeNull(); } ); it( 'should NOT show up in Special:EntityData with rdf', async function () { From d1bc50fd25b748651cf13669c669b3e6800410f1 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 11:13:08 +0100 Subject: [PATCH 12/26] expect --- test/specs/quickstatements/quickstatements.ts | 17 ++++++----------- 1 file changed, 6 insertions(+), 11 deletions(-) diff --git a/test/specs/quickstatements/quickstatements.ts b/test/specs/quickstatements/quickstatements.ts index e15937064..f5b03db56 100644 --- a/test/specs/quickstatements/quickstatements.ts +++ b/test/specs/quickstatements/quickstatements.ts @@ -117,7 +117,6 @@ describe( 'QuickStatements Service', function () { await browser.executeQuickStatement( 'CREATE\nLAST|Len|"Best label"' ); const responseQ3Data = await SpecialEntityDataPage.getData( 'Q3' ); - expect( responseQ3Data.entities.Q3.labels.en.value ).toBe( 'Best label' ); } ); @@ -142,7 +141,6 @@ describe( 'QuickStatements Service', function () { // go look at wikibase const responseQ1Data = await SpecialEntityDataPage.getData( 'Q1' ); - expect( lodash.isEmpty( responseQ1Data.entities.Q1.aliases ) ).toBe( false ); } ); @@ -151,7 +149,6 @@ describe( 'QuickStatements Service', function () { // go look at wikibase const responseQ1Data = await SpecialEntityDataPage.getData( 'Q1' ); - expect( lodash.isEmpty( responseQ1Data.entities.Q1.labels ) ).toBe( false ); } ); @@ -160,7 +157,6 @@ describe( 'QuickStatements Service', function () { // go look at wikibase const responseQ1Data = await SpecialEntityDataPage.getData( 'Q1' ); - expect( lodash.isEmpty( responseQ1Data.entities.Q1.descriptions ) ).toBe( false ); } ); @@ -169,7 +165,6 @@ describe( 'QuickStatements Service', function () { // go look at wikibase const responseQ1Data = await SpecialEntityDataPage.getData( 'Q1' ); - expect( lodash.isEmpty( responseQ1Data.entities.Q1.sitelinks ) ).toBe( false ); } ); @@ -263,9 +258,9 @@ describe( 'QuickStatements Service', function () { const response = await browser.makeRequest( `${ testEnv.vars.WIKIBASE_URL }/w/api.php?action=wbgetclaims&format=json&entity=${ itemId }` ); - const refValue = getReferenceValue( response, propertyIdItem, propertyURL ); - - expect( refValue ).toBe( 'https://www.wikidata.org' ); + expect( getReferenceValue( response, propertyIdItem, propertyURL ) ).toBe( + 'https://www.wikidata.org' + ); } ); it( 'Should be able to add a property with "string" reference', async function () { @@ -279,9 +274,9 @@ describe( 'QuickStatements Service', function () { const response = await browser.makeRequest( `${ testEnv.vars.WIKIBASE_URL }/w/api.php?action=wbgetclaims&format=json&entity=${ itemId }` ); - const refValue = getReferenceValue( response, propertyIdItem, propertyId ); - - expect( refValue ).toBe( 'some string' ); + expect( getReferenceValue( response, propertyIdItem, propertyId ) ).toBe( + 'some string' + ); } ); it( 'Should be able to add and remove a property on an item', async function () { From af04aec28a31b3b5fc2203e6b95475197012601d Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 11:13:50 +0100 Subject: [PATCH 13/26] toHaveAttrContaining --- test/specs/repo/extensions/entityschema.ts | 7 +++---- test/specs/repo/extensions/wikibase-local-media.ts | 7 +++---- 2 files changed, 6 insertions(+), 8 deletions(-) diff --git a/test/specs/repo/extensions/entityschema.ts b/test/specs/repo/extensions/entityschema.ts index 1717209d2..47fce1624 100644 --- a/test/specs/repo/extensions/entityschema.ts +++ b/test/specs/repo/extensions/entityschema.ts @@ -50,10 +50,9 @@ describe( 'EntitySchema', function () { 'Should contain mw-highlight class in HTML' ); - const linkUrl = await $( '.external.entityschema-check-schema' ).getAttribute( - 'href' + await expect( $( '.external.entityschema-check-schema' ) ).toHaveAttrContaining( + 'href', + 'http://validator.svc' ); - - expect( linkUrl.includes( 'http://validator.svc' ) ).toBe( true ); } ); } ); diff --git a/test/specs/repo/extensions/wikibase-local-media.ts b/test/specs/repo/extensions/wikibase-local-media.ts index 7e79a6c65..bf283b77e 100644 --- a/test/specs/repo/extensions/wikibase-local-media.ts +++ b/test/specs/repo/extensions/wikibase-local-media.ts @@ -57,11 +57,10 @@ describe( 'WikibaseLocalMedia', function () { const itemId = await WikibaseApi.createItem( 'image-test', data ); await ItemPage.open( itemId ); - const imageSource = await $( '.wikibase-snakview-value img' ).getAttribute( - 'src' + await expect( $( '.wikibase-snakview-value img' ) ).toHaveAttrContaining( + 'src', + 'Image.png' ); - - expect( imageSource.includes( 'Image.png' ) ).toBe( true ); } ); it( 'Should allow to use uploaded image on statement in UI', async function () { From c784360d30733dedb844cc0d7494605f697a1cf4 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 11:26:44 +0100 Subject: [PATCH 14/26] chill --- test/specs/repo/extensions/entityschema.ts | 16 +++++----------- 1 file changed, 5 insertions(+), 11 deletions(-) diff --git a/test/specs/repo/extensions/entityschema.ts b/test/specs/repo/extensions/entityschema.ts index 47fce1624..4198a0891 100644 --- a/test/specs/repo/extensions/entityschema.ts +++ b/test/specs/repo/extensions/entityschema.ts @@ -33,18 +33,12 @@ describe( 'EntitySchema', function () { await $( '#entityschema-schema-text' ); const entitySchemaEl = await $( '#entityschema-schema-text' ); - const actualTemplate = ( await entitySchemaEl.getText() ).trim(); const actualTemplateHtml = ( await entitySchemaEl.getHTML() ).trim(); - const actualLabel = ( await $( '.entityschema-title-label' ).getText() ).trim(); - const actualId = ( await $( '.entityschema-title-id' ).getText() ).trim(); - const actualDescription = ( - await $( '.entityschema-description' ).getText() - ).trim(); - - expect( actualDescription ).toBe( testDescription ); - expect( actualTemplate ).toBe( shexTemplate ); - expect( actualLabel ).toBe( testLabel ); - expect( actualId ).toBe( '(E1)' ); + + await expect( $( '.entityschema-description' ) ).toHaveText( testDescription ); + await expect( entitySchemaEl ).toHaveText( shexTemplate ); + await expect( $( '.entityschema-title-label' ) ).toHaveText( testLabel ); + await expect( $( '.entityschema-title-id' ) ).toHaveText( '(E1)' ); assert.ok( actualTemplateHtml.includes( 'mw-highlight' ), 'Should contain mw-highlight class in HTML' From 36695ae39268902541767f8d3e51cf3c766ee5b0 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 11:41:12 +0100 Subject: [PATCH 15/26] Cleanup entityschema --- test/specs/repo/extensions/entityschema.ts | 10 ++-------- 1 file changed, 2 insertions(+), 8 deletions(-) diff --git a/test/specs/repo/extensions/entityschema.ts b/test/specs/repo/extensions/entityschema.ts index 4198a0891..1e9461423 100644 --- a/test/specs/repo/extensions/entityschema.ts +++ b/test/specs/repo/extensions/entityschema.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import { readFile } from 'fs/promises'; import { utf8 } from '../../../helpers/readFileEncoding.js'; @@ -32,17 +31,12 @@ describe( 'EntitySchema', function () { await $( '#entityschema-schema-text' ); - const entitySchemaEl = await $( '#entityschema-schema-text' ); - const actualTemplateHtml = ( await entitySchemaEl.getHTML() ).trim(); - + const entitySchemaEl = $( '#entityschema-schema-text' ); await expect( $( '.entityschema-description' ) ).toHaveText( testDescription ); await expect( entitySchemaEl ).toHaveText( shexTemplate ); await expect( $( '.entityschema-title-label' ) ).toHaveText( testLabel ); await expect( $( '.entityschema-title-id' ) ).toHaveText( '(E1)' ); - assert.ok( - actualTemplateHtml.includes( 'mw-highlight' ), - 'Should contain mw-highlight class in HTML' - ); + await expect( entitySchemaEl.$( 'div' ) ).toHaveElementClass( 'mw-highlight' ); await expect( $( '.external.entityschema-check-schema' ) ).toHaveAttrContaining( 'href', From 3c951c0c3f34c063d617bf0b08a79257a6aa8ac5 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 11:47:38 +0100 Subject: [PATCH 16/26] Cleanup item.ts --- test/specs/fedprops/item.ts | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/test/specs/fedprops/item.ts b/test/specs/fedprops/item.ts index 0186acddc..65e746b4e 100644 --- a/test/specs/fedprops/item.ts +++ b/test/specs/fedprops/item.ts @@ -16,11 +16,9 @@ describe( 'Fed props Item', function () { const result = await browser.makeRequest( `${ testEnv.vars.WIKIBASE_URL }/w/api.php?action=wbsearchentities&search=ISNI&format=json&language=en&type=property` ); - const success = result.data.success; - const searchResults = result.data.search; - expect( success ).toBe( 1 ); - expect( searchResults.length ).toBeGreaterThan( 0 ); + expect( result.data.success ).toBe( 1 ); + expect( result.data.search.length ).toBeGreaterThan( 0 ); } ); it( 'can add a federated property and it shows up in the ui', async function () { From 30bd1370f6c499386ddc30aa0b64c88a180f3031 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Sat, 2 Mar 2024 12:31:06 +0100 Subject: [PATCH 17/26] resolves --- test/specs/fedprops/item.ts | 52 ++++++++++++++-------------- test/specs/fedprops/prefetching.ts | 6 ++-- test/specs/repo/property.ts | 12 +++---- test/specs/repo/queryservice.ts | 54 +++++++++++++++--------------- 4 files changed, 64 insertions(+), 60 deletions(-) diff --git a/test/specs/fedprops/item.ts b/test/specs/fedprops/item.ts index 65e746b4e..c062f9253 100644 --- a/test/specs/fedprops/item.ts +++ b/test/specs/fedprops/item.ts @@ -85,12 +85,12 @@ describe( 'Fed props Item', function () { await QueryServiceUIPage.resultTable; // Item should never have made its way into the query service, as TTL doesnt work - expect( - await QueryServiceUIPage.resultIncludes( + await expect( + QueryServiceUIPage.resultIncludes( `<${ testEnv.vars.WIKIBASE_URL }/entity/${ itemId }>`, propertyValue ) - ).toBe( false ); + ).resolves.toBe( false ); } ); it( 'should NOT show up in queryservice ui after creation', async function () { @@ -101,31 +101,33 @@ describe( 'Fed props Item', function () { await QueryServiceUIPage.resultTable; // Item should never have made its way into the query service, as TTL doesnt work - expect( await QueryServiceUIPage.resultIncludes( 'schema:version' ) ).toBe( - false - ); - expect( await QueryServiceUIPage.resultIncludes( 'schema:dateModified' ) ).toBe( - false - ); - expect( await QueryServiceUIPage.resultIncludes( 'wikibase:timestamp' ) ).toBe( - false - ); + await expect( + QueryServiceUIPage.resultIncludes( 'schema:version' ) + ).resolves.toBe( false ); + await expect( + QueryServiceUIPage.resultIncludes( 'schema:dateModified' ) + ).resolves.toBe( false ); + await expect( + QueryServiceUIPage.resultIncludes( 'wikibase:timestamp' ) + ).resolves.toBe( false ); - expect( - await QueryServiceUIPage.resultIncludes( 'rdfs:label', itemLabel ) - ).toBe( false ); + await expect( + QueryServiceUIPage.resultIncludes( 'rdfs:label', itemLabel ) + ).resolves.toBe( false ); - expect( - await QueryServiceUIPage.resultIncludes( 'wikibase:statements', '1' ) - ).toBe( false ); + await expect( + QueryServiceUIPage.resultIncludes( 'wikibase:statements', '1' ) + ).resolves.toBe( false ); - expect( - await QueryServiceUIPage.resultIncludes( 'wikibase:sitelinks', '0' ) - ).toBe( false ); - expect( - await QueryServiceUIPage.resultIncludes( 'wikibase:identifiers', '1' ) - ).toBe( false ); + await expect( + QueryServiceUIPage.resultIncludes( 'wikibase:sitelinks', '0' ) + ).resolves.toBe( false ); + await expect( + QueryServiceUIPage.resultIncludes( 'wikibase:identifiers', '1' ) + ).resolves.toBe( false ); - expect( await QueryServiceUIPage.resultIncludes( 'p:P213' ) ).toBe( false ); + await expect( QueryServiceUIPage.resultIncludes( 'p:P213' ) ).resolves.toBe( + false + ); } ); } ); diff --git a/test/specs/fedprops/prefetching.ts b/test/specs/fedprops/prefetching.ts index bc347a1d7..0ce4f1eea 100644 --- a/test/specs/fedprops/prefetching.ts +++ b/test/specs/fedprops/prefetching.ts @@ -67,7 +67,9 @@ describe( 'Property Prefetching', function () { await $( '#pagehistory' ); // +1 for the initial item creation - expect( await $$( '#pagehistory li' ) ).toHaveLength( NUM_PROPERTIES + 1 ); + await expect( $$( '#pagehistory li' ) ).resolves.toHaveLength( + NUM_PROPERTIES + 1 + ); } ); it( 'Should render recent changes list within threshold', async function () { @@ -79,6 +81,6 @@ describe( 'Property Prefetching', function () { // +1 for the initial item creation // +1 for the Main Page creation? // +1 for ? - expect( await $$( 'ul.special li' ) ).toHaveLength( NUM_PROPERTIES + 3 ); + await expect( $$( 'ul.special li' ) ).resolves.toHaveLength( NUM_PROPERTIES + 3 ); } ); } ); diff --git a/test/specs/repo/property.ts b/test/specs/repo/property.ts index be885cbcc..ad444440c 100644 --- a/test/specs/repo/property.ts +++ b/test/specs/repo/property.ts @@ -96,9 +96,9 @@ describe( 'Property', function () { it( 'Should be able to revert a change', async function () { await $( '=View history' ).click(); - await expect( await $( 'ul.mw-contributions-list' ).$$( 'li' ) ).toHaveLength( - 3 - ); + await expect( + $( 'ul.mw-contributions-list' ).$$( 'li' ) + ).resolves.toHaveLength( 3 ); await $( 'ul.mw-contributions-list' ).$( 'li.before' ).$( 'a=undo' ).click(); await $( 'label=Summary (will be appended to an automatically generated summary):' @@ -107,9 +107,9 @@ describe( 'Property', function () { await $( 'button=Save page' ).click(); await $( '=View history' ).click(); - await expect( await $( 'ul.mw-contributions-list' ).$$( 'li' ) ).toHaveLength( - 4 - ); + await expect( + $( 'ul.mw-contributions-list' ).$$( 'li' ) + ).resolves.toHaveLength( 4 ); await expect( $( 'span.mw-tag-marker-mw-undo' ) ).toExist(); await expect( $( 'ul.mw-contributions-list' ).$( 'li.before' ) diff --git a/test/specs/repo/queryservice.ts b/test/specs/repo/queryservice.ts index e4c8aa5db..6ef210271 100644 --- a/test/specs/repo/queryservice.ts +++ b/test/specs/repo/queryservice.ts @@ -77,40 +77,40 @@ describe( 'QueryService', function () { await QueryServiceUIPage.submit(); await QueryServiceUIPage.resultTable; - expect( await QueryServiceUIPage.resultIncludes( 'schema:version' ) ).toBe( - true - ); - expect( await QueryServiceUIPage.resultIncludes( 'schema:dateModified' ) ).toBe( - true - ); - expect( await QueryServiceUIPage.resultIncludes( 'wikibase:timestamp' ) ).toBe( - true - ); + await expect( + QueryServiceUIPage.resultIncludes( 'schema:version' ) + ).resolves.toBe( true ); + await expect( + QueryServiceUIPage.resultIncludes( 'schema:dateModified' ) + ).resolves.toBe( true ); + await expect( + QueryServiceUIPage.resultIncludes( 'wikibase:timestamp' ) + ).resolves.toBe( true ); // label should match on the prefix - expect( - await QueryServiceUIPage.resultIncludes( 'rdfs:label', itemLabel ) - ).toBe( true ); + await expect( + QueryServiceUIPage.resultIncludes( 'rdfs:label', itemLabel ) + ).resolves.toBe( true ); // should have one statement - expect( - await QueryServiceUIPage.resultIncludes( 'wikibase:statements', '1' ) - ).toBe( true ); + await expect( + QueryServiceUIPage.resultIncludes( 'wikibase:statements', '1' ) + ).resolves.toBe( true ); - expect( - await QueryServiceUIPage.resultIncludes( 'wikibase:sitelinks', '0' ) - ).toBe( true ); - expect( - await QueryServiceUIPage.resultIncludes( 'wikibase:identifiers', '0' ) - ).toBe( true ); + await expect( + QueryServiceUIPage.resultIncludes( 'wikibase:sitelinks', '0' ) + ).resolves.toBe( true ); + await expect( + QueryServiceUIPage.resultIncludes( 'wikibase:identifiers', '0' ) + ).resolves.toBe( true ); // property value is set with correct rdf - expect( - await QueryServiceUIPage.resultIncludes( + await expect( + QueryServiceUIPage.resultIncludes( `<${ testEnv.vars.WIKIBASE_URL }/prop/direct/${ propertyId }>`, propertyValue ) - ).toBe( true ); + ).resolves.toBe( true ); // query the property using wdt: prefix await QueryServiceUIPage.open( `SELECT * WHERE{ ?s wdt:${ propertyId } ?o }` ); @@ -119,12 +119,12 @@ describe( 'QueryService', function () { await QueryServiceUIPage.resultTable; // should be set only to the item - expect( - await QueryServiceUIPage.resultIncludes( + await expect( + QueryServiceUIPage.resultIncludes( `<${ testEnv.vars.WIKIBASE_URL }/entity/${ itemId }>`, propertyValue ) - ).toBe( true ); + ).resolves.toBe( true ); } ); it( 'Should not show up in queryservice ui after deletion', async function () { From b3364e2348211c2de5323d969cfd56abd62e3f8f Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Mon, 4 Mar 2024 00:51:42 +0100 Subject: [PATCH 18/26] Redundant --- test/specs/repo_client/item.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/test/specs/repo_client/item.ts b/test/specs/repo_client/item.ts index 936e9b2dc..22d42658c 100644 --- a/test/specs/repo_client/item.ts +++ b/test/specs/repo_client/item.ts @@ -70,7 +70,6 @@ describe( 'Item', function () { ); // label should come from repo property expect( bodyText ).toBe( propertyValue ); - expect( bodyText.includes( propertyValue ) ).toBe( true ); } ); // This will generate a change that will dispatch From 8ccc821ee8017aacfb37cc8fc30344c24082b55e Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Mon, 4 Mar 2024 01:12:00 +0100 Subject: [PATCH 19/26] Anything --- .../specs/upgrade/queryservice-post-upgrade.ts | 12 ++++++------ .../queryservice-pre-and-post-upgrade.ts | 18 +++++++++--------- test/specs/upgrade/upgrade.ts | 2 +- 3 files changed, 16 insertions(+), 16 deletions(-) diff --git a/test/specs/upgrade/queryservice-post-upgrade.ts b/test/specs/upgrade/queryservice-post-upgrade.ts index c329973cf..3994b18ad 100644 --- a/test/specs/upgrade/queryservice-post-upgrade.ts +++ b/test/specs/upgrade/queryservice-post-upgrade.ts @@ -92,12 +92,12 @@ describe( 'Wikibase post upgrade', function () { bindings ); - expect( dateModified ).not.toBeNull(); - expect( schemaVersion ).not.toBeNull(); - expect( siteLinks ).not.toBeNull(); - expect( identifiers ).not.toBeNull(); - expect( timestamp ).not.toBeNull(); - expect( statement ).not.toBeNull(); + expect( dateModified ).toBe( expect.anything() ); + expect( schemaVersion ).toBe( expect.anything() ); + expect( siteLinks ).toBe( expect.anything() ); + expect( identifiers ).toBe( expect.anything() ); + expect( timestamp ).toBe( expect.anything() ); + expect( statement ).toBe( expect.anything() ); expect( property.o.value ).toBe( propertyValue ); expect( itemLabelValue.o.value ).toBe( itemLabel ); diff --git a/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts b/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts index 882c2d0cb..e99a16771 100644 --- a/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts +++ b/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts @@ -97,17 +97,17 @@ describe( 'Wikibase post upgrade', function () { bindings ); - expect( dateModified ).not.toBeNull(); - expect( schemaVersion ).not.toBeNull(); - expect( siteLinks ).not.toBeNull(); - expect( identifiers ).not.toBeNull(); - expect( timestamp ).not.toBeNull(); - expect( statement ).not.toBeNull(); - - expect( property ).not.toBeNull(); + expect( dateModified ).toBe( expect.anything() ); + expect( schemaVersion ).toBe( expect.anything() ); + expect( siteLinks ).toBe( expect.anything() ); + expect( identifiers ).toBe( expect.anything() ); + expect( timestamp ).toBe( expect.anything() ); + expect( statement ).toBe( expect.anything() ); + + expect( property ).toBe( expect.anything() ); expect( property.o.value ).toBe( 'UpgradeItemStringValue' ); - expect( itemLabelValue ).not.toBeNull(); + expect( itemLabelValue ).toBe( expect.anything() ); expect( itemLabelValue.o.value ).toBe( 'UpgradeItem' ); } ); } ); diff --git a/test/specs/upgrade/upgrade.ts b/test/specs/upgrade/upgrade.ts index a37c53302..67e603d0c 100644 --- a/test/specs/upgrade/upgrade.ts +++ b/test/specs/upgrade/upgrade.ts @@ -88,6 +88,6 @@ describe( 'Wikibase upgrade', function () { it( 'should show up in Special:EntityData with json', async function () { const data = await SpecialEntityDataPage.getData( oldItemID ); - expect( data.entities[ oldItemID ].claims[ 0 ] ).not.toBeNull(); + expect( data.entities[ oldItemID ].claims[ 0 ] ).toBe( expect.anything() ); } ); } ); From 555404a5b424668204ad4ee5a63dc4bf9784de19 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Mon, 4 Mar 2024 01:30:26 +0100 Subject: [PATCH 20/26] stringContaining --- test/specs/elasticsearch/elasticsearch.ts | 6 +++--- test/specs/pingback/pingback.ts | 4 ++-- test/specs/repo/extensions/babel.ts | 12 ++++++------ test/specs/repo/extensions/scribunto.ts | 2 +- test/specs/repo/queryservice.ts | 18 ++++++++++++------ .../repo_client/extensions/scribunto-item.ts | 2 +- test/specs/repo_client/interwiki-links.ts | 10 ++++++---- 7 files changed, 31 insertions(+), 23 deletions(-) diff --git a/test/specs/elasticsearch/elasticsearch.ts b/test/specs/elasticsearch/elasticsearch.ts index c64188ec8..738e71532 100644 --- a/test/specs/elasticsearch/elasticsearch.ts +++ b/test/specs/elasticsearch/elasticsearch.ts @@ -37,9 +37,9 @@ describe( 'ElasticSearch', function () { let searchResult: SearchResult[]; const testLabel = 'Testitem'; - expect( itemLabel.includes( testLabel ) ).toBe( false ); - expect( itemLabel.toLowerCase().includes( testLabel.toLowerCase() ) ).toBe( - true + expect( itemLabel ).toEqual( expect.not.stringContaining( testLabel ) ); + expect( itemLabel.toLowerCase() ).toEqual( + expect.stringContaining( testLabel.toLowerCase() ) ); await browser.waitUntil( diff --git a/test/specs/pingback/pingback.ts b/test/specs/pingback/pingback.ts index 4fafe1a7d..b640fa046 100644 --- a/test/specs/pingback/pingback.ts +++ b/test/specs/pingback/pingback.ts @@ -8,8 +8,8 @@ describe( 'Pingback', function () { const sqlResult = await browser.dbQuery( 'SELECT * from updatelog where ul_key LIKE "WikibasePingback%"' ); - expect( sqlResult.includes( 'WikibasePingback\t' ) ).toBe( true ); - expect( sqlResult.includes( 'WikibasePingback-1.' ) ).toBe( true ); + expect( sqlResult ).toEqual( expect.stringContaining( 'WikibasePingback\t' ) ); + expect( sqlResult ).toEqual( expect.stringContaining( 'WikibasePingback-1.' ) ); const result = await browser.makeRequest( 'http://mediawiki.svc' ); expect( result.data ).toHaveLength( 2 ); diff --git a/test/specs/repo/extensions/babel.ts b/test/specs/repo/extensions/babel.ts index 131344e0c..0c7f4baf4 100644 --- a/test/specs/repo/extensions/babel.ts +++ b/test/specs/repo/extensions/babel.ts @@ -17,13 +17,13 @@ describe( 'Babel', function () { '{{#babel: sv | en }}' ); - expect( - executionContent.includes( 'Den här användaren har svenska som modersmål.' ) - ).toBe( true ); - expect( - executionContent.includes( + expect( executionContent ).toEqual( + expect.stringContaining( 'Den här användaren har svenska som modersmål.' ) + ); + expect( executionContent ).toEqual( + expect.stringContaining( 'This user has a native understanding of English.' ) - ).toBe( true ); + ); } ); } ); diff --git a/test/specs/repo/extensions/scribunto.ts b/test/specs/repo/extensions/scribunto.ts index 467e8e93e..b6d64a672 100644 --- a/test/specs/repo/extensions/scribunto.ts +++ b/test/specs/repo/extensions/scribunto.ts @@ -25,7 +25,7 @@ describe( 'Scribunto', function () { ); // should come from executed lua script - expect( executionContent.includes( 'Hello, world!' ) ).toBe( true ); + expect( executionContent ).toEqual( expect.stringContaining( 'Hello, world!' ) ); } ); it( 'Should be able to execute lua module within 0.05 seconds', async function () { diff --git a/test/specs/repo/queryservice.ts b/test/specs/repo/queryservice.ts index 6ef210271..5b6c13930 100644 --- a/test/specs/repo/queryservice.ts +++ b/test/specs/repo/queryservice.ts @@ -154,14 +154,20 @@ describe( 'QueryService', function () { const resultText = await QueryServiceUIPage.resultTable.getText(); // item should not be included - expect( resultText.includes( 'schema:version' ) ).toBe( false ); - expect( resultText.includes( 'schema:dateModified' ) ).toBe( false ); - expect( resultText.includes( 'wikibase:sitelinks' ) ).toBe( false ); - expect( resultText.includes( 'wikibase:identifiers' ) ).toBe( false ); - expect( resultText.includes( 'rdfs:label' ) ).toBe( false ); + expect( resultText ).toEqual( expect.not.stringContaining( 'schema:version' ) ); + expect( resultText ).toEqual( + expect.not.stringContaining( 'schema:dateModified' ) + ); + expect( resultText ).toEqual( + expect.not.stringContaining( 'wikibase:sitelinks' ) + ); + expect( resultText ).toEqual( + expect.not.stringContaining( 'wikibase:identifiers' ) + ); + expect( resultText ).toEqual( expect.not.stringContaining( 'rdfs:label' ) ); // timestamp always shows - expect( resultText.includes( 'wikibase:timestamp' ) ).toBe( true ); + expect( resultText ).toEqual( expect.stringContaining( 'wikibase:timestamp' ) ); } ); it( 'Should show results for a select query', async function () { diff --git a/test/specs/repo_client/extensions/scribunto-item.ts b/test/specs/repo_client/extensions/scribunto-item.ts index 95ca1ce68..1092a768e 100644 --- a/test/specs/repo_client/extensions/scribunto-item.ts +++ b/test/specs/repo_client/extensions/scribunto-item.ts @@ -67,7 +67,7 @@ describe( 'Scribunto Item', function () { ); // should come from executed lua script - expect( executionContent.includes( itemLabel ) ).toBe( true ); + expect( executionContent ).toEqual( expect.stringContaining( itemLabel ) ); } ); // This will generate a change that will dispatch diff --git a/test/specs/repo_client/interwiki-links.ts b/test/specs/repo_client/interwiki-links.ts index dfddd0e43..bc4abd065 100644 --- a/test/specs/repo_client/interwiki-links.ts +++ b/test/specs/repo_client/interwiki-links.ts @@ -16,9 +16,9 @@ describe( 'Interwiki links', function () { const clientWikiQueryResults = await browser.dbQuery( 'SELECT iw_url FROM interwiki WHERE iw_prefix = "client_wiki"' ); - expect( - clientWikiQueryResults.includes( testEnv.vars.WIKIBASE_CLIENT_URL ) - ).toBe( true ); + expect( clientWikiQueryResults ).toEqual( + expect.stringContaining( testEnv.vars.WIKIBASE_CLIENT_URL ) + ); const config = { user: testEnv.vars.DB_USER, @@ -35,6 +35,8 @@ describe( 'Interwiki links', function () { 'SELECT iw_url FROM interwiki WHERE iw_prefix = "my_wiki"', config ); - expect( myWikiQueryResults.includes( testEnv.vars.WIKIBASE_URL ) ).toBe( true ); + expect( myWikiQueryResults ).toEqual( + expect.stringContaining( testEnv.vars.WIKIBASE_URL ) + ); } ); } ); From 85e1cf1f0f5fa714931bab88a98f44a342eceb70 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Mon, 4 Mar 2024 01:38:25 +0100 Subject: [PATCH 21/26] toEqual --- test/specs/repo_client/extensions/scribunto-item.ts | 3 +-- test/specs/repo_client/item.ts | 5 ++--- 2 files changed, 3 insertions(+), 5 deletions(-) diff --git a/test/specs/repo_client/extensions/scribunto-item.ts b/test/specs/repo_client/extensions/scribunto-item.ts index 1092a768e..595aa4533 100644 --- a/test/specs/repo_client/extensions/scribunto-item.ts +++ b/test/specs/repo_client/extensions/scribunto-item.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import { readFile } from 'fs/promises'; import { stringify } from 'querystring'; import LoginPage from 'wdio-mediawiki/LoginPage.js'; @@ -104,6 +103,6 @@ describe( 'Scribunto Item', function () { expectedDeletionChange ); - assert.deepStrictEqual( actualChange, expectedDeletionChange ); + expect( actualChange ).toEqual( expectedDeletionChange ); } ); } ); diff --git a/test/specs/repo_client/item.ts b/test/specs/repo_client/item.ts index 22d42658c..d62eb39ad 100644 --- a/test/specs/repo_client/item.ts +++ b/test/specs/repo_client/item.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import { stringify } from 'querystring'; import LoginPage from 'wdio-mediawiki/LoginPage.js'; import { getTestString } from 'wdio-mediawiki/Util.js'; @@ -102,7 +101,7 @@ describe( 'Item', function () { expectedSiteLinkChange ); - assert.deepStrictEqual( actualChange, expectedSiteLinkChange ); + expect( actualChange ).toEqual( expectedSiteLinkChange ); } ); // This will generate a change that will dispatch @@ -139,6 +138,6 @@ describe( 'Item', function () { expectedTestDeletionChange ); - assert.deepStrictEqual( actualChange, expectedTestDeletionChange ); + expect( actualChange ).toEqual( expectedTestDeletionChange ); } ); } ); From 2340c7bcbaf873576d4e43e8c12bfc27eaea8f1d Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Mon, 4 Mar 2024 02:18:55 +0100 Subject: [PATCH 22/26] Whoops --- .../specs/upgrade/queryservice-post-upgrade.ts | 12 ++++++------ .../queryservice-pre-and-post-upgrade.ts | 18 +++++++++--------- test/specs/upgrade/upgrade.ts | 2 +- 3 files changed, 16 insertions(+), 16 deletions(-) diff --git a/test/specs/upgrade/queryservice-post-upgrade.ts b/test/specs/upgrade/queryservice-post-upgrade.ts index 3994b18ad..1de526e37 100644 --- a/test/specs/upgrade/queryservice-post-upgrade.ts +++ b/test/specs/upgrade/queryservice-post-upgrade.ts @@ -92,12 +92,12 @@ describe( 'Wikibase post upgrade', function () { bindings ); - expect( dateModified ).toBe( expect.anything() ); - expect( schemaVersion ).toBe( expect.anything() ); - expect( siteLinks ).toBe( expect.anything() ); - expect( identifiers ).toBe( expect.anything() ); - expect( timestamp ).toBe( expect.anything() ); - expect( statement ).toBe( expect.anything() ); + expect( dateModified ).toEqual( expect.anything() ); + expect( schemaVersion ).toEqual( expect.anything() ); + expect( siteLinks ).toEqual( expect.anything() ); + expect( identifiers ).toEqual( expect.anything() ); + expect( timestamp ).toEqual( expect.anything() ); + expect( statement ).toEqual( expect.anything() ); expect( property.o.value ).toBe( propertyValue ); expect( itemLabelValue.o.value ).toBe( itemLabel ); diff --git a/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts b/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts index e99a16771..e60246f13 100644 --- a/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts +++ b/test/specs/upgrade/queryservice-pre-and-post-upgrade.ts @@ -97,17 +97,17 @@ describe( 'Wikibase post upgrade', function () { bindings ); - expect( dateModified ).toBe( expect.anything() ); - expect( schemaVersion ).toBe( expect.anything() ); - expect( siteLinks ).toBe( expect.anything() ); - expect( identifiers ).toBe( expect.anything() ); - expect( timestamp ).toBe( expect.anything() ); - expect( statement ).toBe( expect.anything() ); - - expect( property ).toBe( expect.anything() ); + expect( dateModified ).toEqual( expect.anything() ); + expect( schemaVersion ).toEqual( expect.anything() ); + expect( siteLinks ).toEqual( expect.anything() ); + expect( identifiers ).toEqual( expect.anything() ); + expect( timestamp ).toEqual( expect.anything() ); + expect( statement ).toEqual( expect.anything() ); + + expect( property ).toEqual( expect.anything() ); expect( property.o.value ).toBe( 'UpgradeItemStringValue' ); - expect( itemLabelValue ).toBe( expect.anything() ); + expect( itemLabelValue ).toEqual( expect.anything() ); expect( itemLabelValue.o.value ).toBe( 'UpgradeItem' ); } ); } ); diff --git a/test/specs/upgrade/upgrade.ts b/test/specs/upgrade/upgrade.ts index 67e603d0c..2e58706a7 100644 --- a/test/specs/upgrade/upgrade.ts +++ b/test/specs/upgrade/upgrade.ts @@ -88,6 +88,6 @@ describe( 'Wikibase upgrade', function () { it( 'should show up in Special:EntityData with json', async function () { const data = await SpecialEntityDataPage.getData( oldItemID ); - expect( data.entities[ oldItemID ].claims[ 0 ] ).toBe( expect.anything() ); + expect( data.entities[ oldItemID ].claims ).toEqual( expect.anything() ); } ); } ); From 0523453e88baee35facf02fd765ca55b0f1b8449 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Mon, 4 Mar 2024 02:46:48 +0100 Subject: [PATCH 23/26] Last Assert --- test/specs/quickstatements/quickstatements.ts | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/test/specs/quickstatements/quickstatements.ts b/test/specs/quickstatements/quickstatements.ts index f5b03db56..1e4edd1c7 100644 --- a/test/specs/quickstatements/quickstatements.ts +++ b/test/specs/quickstatements/quickstatements.ts @@ -1,4 +1,3 @@ -import assert from 'assert'; import { AxiosResponse } from 'axios'; import lodash from 'lodash'; import WikibaseApi from 'wdio-wikibase/wikibase.api.js'; @@ -241,8 +240,10 @@ describe( 'QuickStatements Service', function () { propertyIdItem ); - assert( typeof refValue !== 'string' ); - expect( refValue.id ).toBe( 'Q2' ); + expect( typeof refValue ).not.toBe( 'string' ); + if ( typeof refValue !== 'string' ) { + expect( refValue.id ).toBe( 'Q2' ); + } } ); it( 'Should be able to add a property with "url" reference', async function () { From 8a8ed28c96c181567a1229826ace90156fa50f0a Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Mon, 4 Mar 2024 02:56:09 +0100 Subject: [PATCH 24/26] Readme --- test/README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/test/README.md b/test/README.md index dd3a051db..b67f76bec 100644 --- a/test/README.md +++ b/test/README.md @@ -61,5 +61,5 @@ you’ll want to consult the documentation of the following libraries we use: (`browser`, `$`, `waitForVisible`, …) * [Mocha](https://mochajs.org/) as the general testing framework (`describe`, `it`, `before`, …) -* [`assert`](https://nodejs.org/api/assert.html) for simple assertions - (`ok`, `strictEqual`, …) +* [`expect`](https://webdriver.io/docs/api/expect-webdriverio/) for assertions + (`toBe`, `toEqual`, …) From 9865e841a8ef8f2dd2408564214cf71b411698c2 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Mon, 4 Mar 2024 12:45:27 +0100 Subject: [PATCH 25/26] containing --- test/specs/elasticsearch/elasticsearch.ts | 6 +++--- test/specs/pingback/pingback.ts | 4 ++-- test/specs/repo/extensions/babel.ts | 12 ++++++------ test/specs/repo/extensions/scribunto.ts | 2 +- test/specs/repo/queryservice.ts | 18 ++++++------------ .../repo_client/extensions/scribunto-item.ts | 2 +- test/specs/repo_client/interwiki-links.ts | 10 ++++------ 7 files changed, 23 insertions(+), 31 deletions(-) diff --git a/test/specs/elasticsearch/elasticsearch.ts b/test/specs/elasticsearch/elasticsearch.ts index 738e71532..c64188ec8 100644 --- a/test/specs/elasticsearch/elasticsearch.ts +++ b/test/specs/elasticsearch/elasticsearch.ts @@ -37,9 +37,9 @@ describe( 'ElasticSearch', function () { let searchResult: SearchResult[]; const testLabel = 'Testitem'; - expect( itemLabel ).toEqual( expect.not.stringContaining( testLabel ) ); - expect( itemLabel.toLowerCase() ).toEqual( - expect.stringContaining( testLabel.toLowerCase() ) + expect( itemLabel.includes( testLabel ) ).toBe( false ); + expect( itemLabel.toLowerCase().includes( testLabel.toLowerCase() ) ).toBe( + true ); await browser.waitUntil( diff --git a/test/specs/pingback/pingback.ts b/test/specs/pingback/pingback.ts index b640fa046..4fafe1a7d 100644 --- a/test/specs/pingback/pingback.ts +++ b/test/specs/pingback/pingback.ts @@ -8,8 +8,8 @@ describe( 'Pingback', function () { const sqlResult = await browser.dbQuery( 'SELECT * from updatelog where ul_key LIKE "WikibasePingback%"' ); - expect( sqlResult ).toEqual( expect.stringContaining( 'WikibasePingback\t' ) ); - expect( sqlResult ).toEqual( expect.stringContaining( 'WikibasePingback-1.' ) ); + expect( sqlResult.includes( 'WikibasePingback\t' ) ).toBe( true ); + expect( sqlResult.includes( 'WikibasePingback-1.' ) ).toBe( true ); const result = await browser.makeRequest( 'http://mediawiki.svc' ); expect( result.data ).toHaveLength( 2 ); diff --git a/test/specs/repo/extensions/babel.ts b/test/specs/repo/extensions/babel.ts index 0c7f4baf4..131344e0c 100644 --- a/test/specs/repo/extensions/babel.ts +++ b/test/specs/repo/extensions/babel.ts @@ -17,13 +17,13 @@ describe( 'Babel', function () { '{{#babel: sv | en }}' ); - expect( executionContent ).toEqual( - expect.stringContaining( 'Den här användaren har svenska som modersmål.' ) - ); - expect( executionContent ).toEqual( - expect.stringContaining( + expect( + executionContent.includes( 'Den här användaren har svenska som modersmål.' ) + ).toBe( true ); + expect( + executionContent.includes( 'This user has a native understanding of English.' ) - ); + ).toBe( true ); } ); } ); diff --git a/test/specs/repo/extensions/scribunto.ts b/test/specs/repo/extensions/scribunto.ts index b6d64a672..467e8e93e 100644 --- a/test/specs/repo/extensions/scribunto.ts +++ b/test/specs/repo/extensions/scribunto.ts @@ -25,7 +25,7 @@ describe( 'Scribunto', function () { ); // should come from executed lua script - expect( executionContent ).toEqual( expect.stringContaining( 'Hello, world!' ) ); + expect( executionContent.includes( 'Hello, world!' ) ).toBe( true ); } ); it( 'Should be able to execute lua module within 0.05 seconds', async function () { diff --git a/test/specs/repo/queryservice.ts b/test/specs/repo/queryservice.ts index 5b6c13930..6ef210271 100644 --- a/test/specs/repo/queryservice.ts +++ b/test/specs/repo/queryservice.ts @@ -154,20 +154,14 @@ describe( 'QueryService', function () { const resultText = await QueryServiceUIPage.resultTable.getText(); // item should not be included - expect( resultText ).toEqual( expect.not.stringContaining( 'schema:version' ) ); - expect( resultText ).toEqual( - expect.not.stringContaining( 'schema:dateModified' ) - ); - expect( resultText ).toEqual( - expect.not.stringContaining( 'wikibase:sitelinks' ) - ); - expect( resultText ).toEqual( - expect.not.stringContaining( 'wikibase:identifiers' ) - ); - expect( resultText ).toEqual( expect.not.stringContaining( 'rdfs:label' ) ); + expect( resultText.includes( 'schema:version' ) ).toBe( false ); + expect( resultText.includes( 'schema:dateModified' ) ).toBe( false ); + expect( resultText.includes( 'wikibase:sitelinks' ) ).toBe( false ); + expect( resultText.includes( 'wikibase:identifiers' ) ).toBe( false ); + expect( resultText.includes( 'rdfs:label' ) ).toBe( false ); // timestamp always shows - expect( resultText ).toEqual( expect.stringContaining( 'wikibase:timestamp' ) ); + expect( resultText.includes( 'wikibase:timestamp' ) ).toBe( true ); } ); it( 'Should show results for a select query', async function () { diff --git a/test/specs/repo_client/extensions/scribunto-item.ts b/test/specs/repo_client/extensions/scribunto-item.ts index 595aa4533..b38d938c4 100644 --- a/test/specs/repo_client/extensions/scribunto-item.ts +++ b/test/specs/repo_client/extensions/scribunto-item.ts @@ -66,7 +66,7 @@ describe( 'Scribunto Item', function () { ); // should come from executed lua script - expect( executionContent ).toEqual( expect.stringContaining( itemLabel ) ); + expect( executionContent.includes( itemLabel ) ).toBe( true ); } ); // This will generate a change that will dispatch diff --git a/test/specs/repo_client/interwiki-links.ts b/test/specs/repo_client/interwiki-links.ts index bc4abd065..dfddd0e43 100644 --- a/test/specs/repo_client/interwiki-links.ts +++ b/test/specs/repo_client/interwiki-links.ts @@ -16,9 +16,9 @@ describe( 'Interwiki links', function () { const clientWikiQueryResults = await browser.dbQuery( 'SELECT iw_url FROM interwiki WHERE iw_prefix = "client_wiki"' ); - expect( clientWikiQueryResults ).toEqual( - expect.stringContaining( testEnv.vars.WIKIBASE_CLIENT_URL ) - ); + expect( + clientWikiQueryResults.includes( testEnv.vars.WIKIBASE_CLIENT_URL ) + ).toBe( true ); const config = { user: testEnv.vars.DB_USER, @@ -35,8 +35,6 @@ describe( 'Interwiki links', function () { 'SELECT iw_url FROM interwiki WHERE iw_prefix = "my_wiki"', config ); - expect( myWikiQueryResults ).toEqual( - expect.stringContaining( testEnv.vars.WIKIBASE_URL ) - ); + expect( myWikiQueryResults.includes( testEnv.vars.WIKIBASE_URL ) ).toBe( true ); } ); } ); From e797876d9a205eb108668d149fe2e6e9557d3cd0 Mon Sep 17 00:00:00 2001 From: Ricki Jay Date: Mon, 4 Mar 2024 14:31:30 +0100 Subject: [PATCH 26/26] Fix Test --- test/specs/upgrade/upgrade.ts | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/test/specs/upgrade/upgrade.ts b/test/specs/upgrade/upgrade.ts index 2e58706a7..afef2fc07 100644 --- a/test/specs/upgrade/upgrade.ts +++ b/test/specs/upgrade/upgrade.ts @@ -89,5 +89,10 @@ describe( 'Wikibase upgrade', function () { it( 'should show up in Special:EntityData with json', async function () { const data = await SpecialEntityDataPage.getData( oldItemID ); expect( data.entities[ oldItemID ].claims ).toEqual( expect.anything() ); + expect( Object.keys( data.entities[ oldItemID ].claims ) ).toHaveLength( 1 ); + const oldPropertyId = Object.keys( data.entities[ oldItemID ].claims )[ 0 ]; + expect( data.entities[ oldItemID ].claims[ oldPropertyId ] ).toEqual( + expect.anything() + ); } ); } );