E2E: add user smoke tests
- Disable captcha + open registrations in E2E Pleroma config - Await login after signup to avoid redirect race - Add basic register/login/post smoke specs - Fix failure artifact copying order
This commit is contained in:
parent
99d2efac6c
commit
7f54706821
4 changed files with 97 additions and 3 deletions
|
|
@ -3,12 +3,26 @@
|
||||||
set -eu
|
set -eu
|
||||||
|
|
||||||
SEED_SENTINEL_PATH="/var/lib/pleroma/.e2e_seeded"
|
SEED_SENTINEL_PATH="/var/lib/pleroma/.e2e_seeded"
|
||||||
|
CONFIG_OVERRIDE_PATH="/var/lib/pleroma/config.exs"
|
||||||
|
|
||||||
echo "-- Waiting for database..."
|
echo "-- Waiting for database..."
|
||||||
while ! pg_isready -U "${DB_USER:-pleroma}" -d "postgres://${DB_HOST:-db}:${DB_PORT:-5432}/${DB_NAME:-pleroma}" -t 1; do
|
while ! pg_isready -U "${DB_USER:-pleroma}" -d "postgres://${DB_HOST:-db}:${DB_PORT:-5432}/${DB_NAME:-pleroma}" -t 1; do
|
||||||
sleep 1s
|
sleep 1s
|
||||||
done
|
done
|
||||||
|
|
||||||
|
echo "-- Writing E2E config overrides..."
|
||||||
|
cat > "$CONFIG_OVERRIDE_PATH" <<'EOF'
|
||||||
|
import Config
|
||||||
|
|
||||||
|
config :pleroma, Pleroma.Captcha,
|
||||||
|
enabled: false
|
||||||
|
|
||||||
|
config :pleroma, :instance,
|
||||||
|
registrations_open: true,
|
||||||
|
account_activation_required: false,
|
||||||
|
approval_required: false
|
||||||
|
EOF
|
||||||
|
|
||||||
echo "-- Running migrations..."
|
echo "-- Running migrations..."
|
||||||
/opt/pleroma/bin/pleroma_ctl migrate
|
/opt/pleroma/bin/pleroma_ctl migrate
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -551,7 +551,7 @@ const users = {
|
||||||
if (data.access_token) {
|
if (data.access_token) {
|
||||||
store.commit('signUpSuccess')
|
store.commit('signUpSuccess')
|
||||||
oauthStore.setToken(data.access_token)
|
oauthStore.setToken(data.access_token)
|
||||||
store.dispatch('loginUser', data.access_token)
|
await store.dispatch('loginUser', data.access_token)
|
||||||
return 'ok'
|
return 'ok'
|
||||||
} else { // Request succeeded, but user cannot login yet.
|
} else { // Request succeeded, but user cannot login yet.
|
||||||
store.commit('signUpNotice', data)
|
store.commit('signUpNotice', data)
|
||||||
|
|
|
||||||
80
test/e2e-playwright/specs/user_smoke.spec.js
Normal file
80
test/e2e-playwright/specs/user_smoke.spec.js
Normal file
|
|
@ -0,0 +1,80 @@
|
||||||
|
import { randomUUID } from 'node:crypto'
|
||||||
|
import { test, expect } from 'playwright/test'
|
||||||
|
|
||||||
|
const createTestUser = () => {
|
||||||
|
const id = randomUUID().slice(0, 8)
|
||||||
|
return {
|
||||||
|
username: `e2e_${id}`,
|
||||||
|
fullname: `E2E ${id}`,
|
||||||
|
email: `e2e_${id}@example.com`,
|
||||||
|
password: 'e2e-password'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const register = async (page, user) => {
|
||||||
|
await page.goto('/registration')
|
||||||
|
|
||||||
|
const registrationForm = page.locator('#main-scroller form.registration-form')
|
||||||
|
await registrationForm.locator('#sign-up-username').fill(user.username)
|
||||||
|
await registrationForm.locator('#sign-up-fullname').fill(user.fullname)
|
||||||
|
await registrationForm.locator('#email').fill(user.email)
|
||||||
|
await registrationForm.locator('#sign-up-password').fill(user.password)
|
||||||
|
await registrationForm.locator('#sign-up-password-confirmation').fill(user.password)
|
||||||
|
await Promise.all([
|
||||||
|
page.waitForURL(/\/main\/friends/),
|
||||||
|
registrationForm.getByRole('button', { name: 'Register' }).click()
|
||||||
|
])
|
||||||
|
}
|
||||||
|
|
||||||
|
const logout = async (page) => {
|
||||||
|
await page.getByTitle('Log out').click()
|
||||||
|
const confirmLogout = page.getByRole('button', { name: 'Logout', exact: true })
|
||||||
|
if (await confirmLogout.isVisible()) {
|
||||||
|
await Promise.all([
|
||||||
|
page.waitForURL(/\/main\/(public|all)/),
|
||||||
|
confirmLogout.click()
|
||||||
|
])
|
||||||
|
} else {
|
||||||
|
await page.waitForURL(/\/main\/(public|all)/)
|
||||||
|
}
|
||||||
|
|
||||||
|
await expect(page.locator('#sidebar form.login-form')).toBeVisible()
|
||||||
|
}
|
||||||
|
|
||||||
|
const login = async (page, user) => {
|
||||||
|
await page.goto('/login')
|
||||||
|
|
||||||
|
const loginForm = page.locator('#main-scroller form.login-form')
|
||||||
|
await loginForm.locator('#username').fill(user.username)
|
||||||
|
await loginForm.locator('#password').fill(user.password)
|
||||||
|
await loginForm.getByRole('button', { name: 'Log in' }).click()
|
||||||
|
|
||||||
|
await page.waitForURL(/\/main\/friends/)
|
||||||
|
}
|
||||||
|
|
||||||
|
test('user can register, log out, and log back in', async ({ page }) => {
|
||||||
|
const user = createTestUser()
|
||||||
|
await register(page, user)
|
||||||
|
await expect(page.getByTitle('Log out')).toBeVisible()
|
||||||
|
|
||||||
|
await logout(page)
|
||||||
|
|
||||||
|
await login(page, user)
|
||||||
|
await expect(page.getByTitle('Log out')).toBeVisible()
|
||||||
|
})
|
||||||
|
|
||||||
|
test('user can post a status', async ({ page }) => {
|
||||||
|
const user = createTestUser()
|
||||||
|
await register(page, user)
|
||||||
|
|
||||||
|
const statusText = `Hello from ${user.username} (${randomUUID().slice(0, 8)})`
|
||||||
|
const composer = page.locator('#sidebar .user-panel .post-status-form')
|
||||||
|
await composer.locator('textarea.form-post-body').fill(statusText)
|
||||||
|
await Promise.all([
|
||||||
|
page.waitForResponse((resp) => resp.request().method() === 'POST' && resp.url().includes('/api/v1/statuses') && resp.ok()),
|
||||||
|
composer.getByRole('button', { name: 'Post', exact: true }).click()
|
||||||
|
])
|
||||||
|
|
||||||
|
await page.goto(`/users/${user.username}`)
|
||||||
|
await expect(page.getByText(statusText)).toBeVisible()
|
||||||
|
})
|
||||||
|
|
@ -24,10 +24,10 @@ result="$?"
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
if [ "$result" -ne 0 ]; then
|
if [ "$result" -ne 0 ]; then
|
||||||
|
docker compose -f "$COMPOSE_FILE" cp e2e:/app/test/e2e-playwright/test-results test/e2e-playwright >/dev/null 2>&1 || true
|
||||||
|
docker compose -f "$COMPOSE_FILE" cp e2e:/app/test/e2e-playwright/playwright-report test/e2e-playwright >/dev/null 2>&1 || true
|
||||||
mkdir -p test/e2e-playwright/test-results
|
mkdir -p test/e2e-playwright/test-results
|
||||||
docker compose -f "$COMPOSE_FILE" logs --no-color pleroma db > test/e2e-playwright/test-results/docker-compose.log 2>/dev/null || true
|
docker compose -f "$COMPOSE_FILE" logs --no-color pleroma db > test/e2e-playwright/test-results/docker-compose.log 2>/dev/null || true
|
||||||
docker compose -f "$COMPOSE_FILE" cp e2e:/app/test/e2e-playwright/test-results test/e2e-playwright/test-results >/dev/null 2>&1 || true
|
|
||||||
docker compose -f "$COMPOSE_FILE" cp e2e:/app/test/e2e-playwright/playwright-report test/e2e-playwright/playwright-report >/dev/null 2>&1 || true
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
cleanup
|
cleanup
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue