1
0
mirror of https://git.cloudron.io/cloudron/gitea-app synced 2026-04-29 22:21:13 +00:00
This commit is contained in:
Girish Ramakrishnan
2026-04-28 11:56:43 +02:00
parent 3d5b4ed571
commit ae8096ed29
Executable → Regular
+22 -58
View File
@@ -4,23 +4,21 @@ import assert from 'node:assert/strict';
import { execSync } from 'node:child_process'; import { execSync } from 'node:child_process';
import fs from 'node:fs'; import fs from 'node:fs';
import path from 'node:path'; import path from 'node:path';
import superagent from '@cloudron/superagent';
import { import {
app, app,
clearCache, clearCache,
click, click,
cloudronCli, cloudronCli,
getText,
goto, goto,
loginOIDC, loginOIDC,
sendKeys, sendKeys,
setInputFiles,
setupBrowser, setupBrowser,
takeScreenshot, takeScreenshot,
teardownBrowser, teardownBrowser,
username, username,
waitFor, waitFor,
waitForUrl waitForUrl,
press
} from '@cloudron/charlie'; } from '@cloudron/charlie';
/* global it, describe, before, after, afterEach */ /* global it, describe, before, after, afterEach */
@@ -41,29 +39,12 @@ describe('Application life cycle test', function () {
await takeScreenshot(this.currentTest.title); await takeScreenshot(this.currentTest.title);
}); });
async function setAvatar() {
await goto(`https://${app.fqdn}/user/settings`, '//label[contains(text(), "Use Custom Avatar")]');
await click('//label[contains(text(), "Use Custom Avatar")]');
await setInputFiles('//input[@type="file" and @name="avatar"]', path.resolve(import.meta.dirname, '../logo.png'));
await click('//button[contains(text(), "Update Avatar")]');
await waitFor('Your avatar has been updated.');
}
async function checkAvatar() {
await goto(`https://${app.fqdn}/${username}`, '//div[@id="profile-avatar"]/a/img');
const avatarSrc = await getText('//div[@id="profile-avatar"]/a/img', 'src');
assert.ok(avatarSrc);
const avatarUrl = new URL(avatarSrc, `https://${app.fqdn}`).href;
const response = await superagent.get(avatarUrl);
assert.strictEqual(response.status, 200);
}
async function login(user, passwd) { async function login(user, passwd) {
await goto(`https://${app.fqdn}/user/login`, 'css=#user_name'); await goto(`https://${app.fqdn}/user/login`, 'label=Username or Email Address');
await sendKeys('css=#user_name', user); await sendKeys('label=Username or Email Address', user);
await sendKeys('css=#password', passwd); await sendKeys('label=Password', passwd);
await click('//form[@action="/user/login"]//button'); await click('Sign In', { role: 'button' }); // there is a sign in link at the top
await waitFor('xpath=//nav//img[contains(@class, "avatar")]'); await waitFor('Milestones');
} }
async function adminLogin() { async function adminLogin() {
@@ -72,23 +53,13 @@ describe('Application life cycle test', function () {
async function loginGiteaOIDC() { async function loginGiteaOIDC() {
await clearCache(); await clearCache();
await goto(`https://${app.fqdn}/user/login`, '//a[@href="/user/oauth2/cloudron"]'); await goto(`https://${app.fqdn}/user/login`, /Sign in with/);
await click('//a[@href="/user/oauth2/cloudron"]'); await click(/Sign in with/);
await loginOIDC('//nav//img[contains(@class, "avatar")]'); await loginOIDC('Milestones');
}
async function loginGiteaOIDCOld() {
await clearCache();
await goto(`https://${app.fqdn}/user/login`, '//a[contains(@class, "openidConnect")]');
await click('//a[contains(@class, "openidConnect") and contains(., "Sign in with cloudron")]');
await loginOIDC('//nav//img[contains(@class, "avatar")]');
} }
async function logout() { async function logout() {
await goto(`https://${app.fqdn}`, '//nav//img[contains(@class, "avatar")]'); await clearCache();
await click('//nav//img[contains(@class, "avatar")]');
await waitFor('css=a[href="/user/logout"]');
await click('//a[@href="/user/logout"]');
} }
async function addPublicKey() { async function addPublicKey() {
@@ -96,18 +67,18 @@ describe('Application life cycle test', function () {
fs.chmodSync(keyPath, 0o600); fs.chmodSync(keyPath, 0o600);
await goto(`https://${app.fqdn}/user/settings/keys`, 'css=#add-ssh-button'); await goto(`https://${app.fqdn}/user/settings/keys`, 'css=#add-ssh-button');
await click('css=#add-ssh-button'); await click('css=#add-ssh-button'); // there are two Add key buttons
await sendKeys('css=#ssh-key-title', 'testkey'); await sendKeys('label=Content', fs.readFileSync(`${import.meta.dirname}/id_ed25519.pub`, 'utf8').trim()); // there are two Content labels
await sendKeys('css=#ssh-key-content', fs.readFileSync(`${import.meta.dirname}/id_ed25519.pub`, 'utf8').trim()); await sendKeys('label=Key Name', 'testkey');
await click('//form//button[contains(text(),"Add Key")]'); await press('label=Key Name', 'Enter');
await waitFor('has been added.'); await waitFor(/has been added/);
} }
async function createRepo() { async function createRepo() {
await goto(`https://${app.fqdn}/repo/create`, 'css=#repo_name'); await goto(`https://${app.fqdn}/repo/create`, 'label=Repository Name');
await sendKeys('css=#repo_name', reponame); await sendKeys('label=Repository Name', reponame);
await click('css=#auto-init'); await click(/Initialize Repository/);
await click('//button[contains(text(), "Create Repository")]'); await click('Create Repository');
await waitForUrl(`https://${app.fqdn}/${username}/${reponame}`); await waitForUrl(`https://${app.fqdn}/${username}/${reponame}`);
} }
@@ -140,8 +111,6 @@ describe('Application life cycle test', function () {
it('can logout', logout); it('can logout', logout);
it('can login', loginGiteaOIDC); it('can login', loginGiteaOIDC);
it('can set avatar', setAvatar);
it('can get avatar', checkAvatar);
it('can add public key', addPublicKey); it('can add public key', addPublicKey);
@@ -160,7 +129,6 @@ describe('Application life cycle test', function () {
it('restore app', cloudronCli.restoreFromLatestBackup); it('restore app', cloudronCli.restoreFromLatestBackup);
it('can login', loginGiteaOIDC); it('can login', loginGiteaOIDC);
it('can get avatar', checkAvatar);
it('can clone the url', cloneRepo); it('can clone the url', cloneRepo);
it('file exists in repo', function () { it('file exists in repo', function () {
assert.strictEqual(fs.existsSync(`${repodir}/newfile`), true); assert.strictEqual(fs.existsSync(`${repodir}/newfile`), true);
@@ -169,7 +137,6 @@ describe('Application life cycle test', function () {
it('move to different location', cloudronCli.changeLocation); it('move to different location', cloudronCli.changeLocation);
it('can login', loginGiteaOIDC); it('can login', loginGiteaOIDC);
it('can get avatar', checkAvatar);
it('can clone the url', cloneRepo); it('can clone the url', cloneRepo);
it('file exists in repo', function () { it('file exists in repo', function () {
assert.strictEqual(fs.existsSync(`${repodir}/newfile`), true); assert.strictEqual(fs.existsSync(`${repodir}/newfile`), true);
@@ -186,13 +153,11 @@ describe('Application life cycle test', function () {
it('uninstall app (no sso)', cloudronCli.uninstall); it('uninstall app (no sso)', cloudronCli.uninstall);
it('can install app', async function () { it('can install app from appstore', async function () {
await cloudronCli.appstoreInstall({ tcpPortFlags: INSTALL_TCP_FLAGS }); await cloudronCli.appstoreInstall({ tcpPortFlags: INSTALL_TCP_FLAGS });
}); });
it('can login', loginGiteaOIDCOld); it('can login', loginGiteaOIDC);
it('can set avatar', setAvatar);
it('can get avatar', checkAvatar);
it('can add public key', addPublicKey); it('can add public key', addPublicKey);
it('can create repo', createRepo); it('can create repo', createRepo);
it('can clone the url', cloneRepo); it('can clone the url', cloneRepo);
@@ -204,7 +169,6 @@ describe('Application life cycle test', function () {
it('can logout', logout); it('can logout', logout);
it('can login', loginGiteaOIDC); it('can login', loginGiteaOIDC);
it('can get avatar', checkAvatar);
it('can clone the url', cloneRepo); it('can clone the url', cloneRepo);
it('file exists in cloned repo', fileExists); it('file exists in cloned repo', fileExists);