tests: quicker login, tweak test setup (#372)
* make tests faster by logging in directly * downgrade testcafe * Revert "downgrade testcafe" This reverts commit0f78f5ef63
. * try a delay * the delay does not do anything * disable concurrency in testcafe * make setup script less noisy * try transparency of 2? * Revert "the delay does not do anything" This reverts commit438b3519a4
. * try a delay of 400ms * okay fine delay of 1s * try concurrency of 4 again
This commit is contained in:
parent
992c3a890d
commit
e8d2cd9ffc
|
@ -45,6 +45,7 @@ export async function restoreMastodonData () {
|
|||
console.log('Restoring mastodon data...')
|
||||
let internalIdsToIds = {}
|
||||
for (let action of actions) {
|
||||
await new Promise(resolve => setTimeout(resolve, 1000)) // delay so that notifications have proper order
|
||||
console.log(JSON.stringify(action))
|
||||
let accessToken = users[action.user].accessToken
|
||||
|
||||
|
|
|
@ -1,7 +1,6 @@
|
|||
#!/usr/bin/env bash
|
||||
|
||||
set -e
|
||||
set -x
|
||||
|
||||
if [[ "$COMMAND" = deploy-dev-travis ]]; then
|
||||
exit 0 # no need to setup mastodon in this case
|
||||
|
|
|
@ -0,0 +1,32 @@
|
|||
<!-- this is only used in the tests, to log in quickly -->
|
||||
<script>
|
||||
import { store } from '../_store/store'
|
||||
import { goto } from 'sapper/runtime.js'
|
||||
|
||||
export default {
|
||||
oncreate () {
|
||||
let accessToken = location.search.match(/accessToken=([^&]+)/)[1]
|
||||
let instanceName = location.search.match(/instanceName=([^&]+)/)[1]
|
||||
let {
|
||||
loggedInInstances,
|
||||
loggedInInstancesInOrder
|
||||
} = store.get()
|
||||
|
||||
loggedInInstances[instanceName] = {
|
||||
access_token: accessToken
|
||||
}
|
||||
|
||||
if (!loggedInInstancesInOrder.includes(instanceName)) {
|
||||
loggedInInstancesInOrder.push(instanceName)
|
||||
}
|
||||
|
||||
store.set({
|
||||
currentInstance: instanceName,
|
||||
loggedInInstances,
|
||||
loggedInInstancesInOrder
|
||||
})
|
||||
store.save()
|
||||
goto('/')
|
||||
}
|
||||
}
|
||||
</script>
|
|
@ -1,22 +1,9 @@
|
|||
import {
|
||||
authorizeInput, emailInput, getUrl, instanceInput, mastodonLogInButton,
|
||||
passwordInput,
|
||||
sleep
|
||||
} from './utils'
|
||||
import { getUrl } from './utils'
|
||||
import { users } from './users'
|
||||
|
||||
async function login (t, username, password) {
|
||||
await sleep(500)
|
||||
await t.typeText(instanceInput, 'localhost:3000', {paste: true})
|
||||
await sleep(500)
|
||||
return t
|
||||
.pressKey('enter')
|
||||
.expect(getUrl()).eql('http://localhost:3000/auth/sign_in', {timeout: 30000})
|
||||
.typeText(emailInput, username, {paste: true})
|
||||
.typeText(passwordInput, password, {paste: true})
|
||||
.click(mastodonLogInButton)
|
||||
.expect(getUrl()).contains('/oauth/authorize')
|
||||
.click(authorizeInput)
|
||||
// quick login using a secret page and a known access token (makes tests run faster)
|
||||
async function login (t, user) {
|
||||
await t.navigateTo(`/settings/quick-login?instanceName=localhost:3000&accessToken=${user.accessToken}`)
|
||||
.expect(getUrl()).eql('http://localhost:4002/', {timeout: 30000})
|
||||
}
|
||||
|
||||
|
@ -30,11 +17,9 @@ async function login (t, username, password) {
|
|||
// })
|
||||
|
||||
export async function loginAsFoobar (t) {
|
||||
await t.navigateTo('/settings/instances/add')
|
||||
await login(t, users.foobar.email, users.foobar.password)
|
||||
await login(t, users.foobar)
|
||||
}
|
||||
|
||||
export async function loginAsLockedAccount (t) {
|
||||
await t.navigateTo('/settings/instances/add')
|
||||
await login(t, users.LockedAccount.email, users.LockedAccount.password)
|
||||
await login(t, users.LockedAccount)
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue