aboutsummaryrefslogtreecommitdiffstats
path: root/tests/functional/dashboard/account.spec.ts
diff options
context:
space:
mode:
authorLibravatar Ricardo <ricardo@cino.io>2023-10-13 14:12:03 +0200
committerLibravatar GitHub <noreply@github.com>2023-10-13 13:12:03 +0100
commite503468660a13760010a94ecda5f0625c6f47f87 (patch)
treefa532f54fc5f091de08d55405ec6339bd2440a02 /tests/functional/dashboard/account.spec.ts
parent1.3.16 [skip ci] (diff)
downloadferdium-server-e503468660a13760010a94ecda5f0625c6f47f87.tar.gz
ferdium-server-e503468660a13760010a94ecda5f0625c6f47f87.tar.zst
ferdium-server-e503468660a13760010a94ecda5f0625c6f47f87.zip
Server re-build with latest AdonisJS framework & Typescript (#47)
* chore: setup first basis structure * chore: ensure styling is loaded correctly * chore: comply to new routing syntax by replace . with / in routes/resource locations * chore: add login controller * chore: correctly use views with slash instead of dot * chore: working login + tests * chore: clean up tests * chore: add password-forgot endpoint and matching test * chore: add delete page test * chore: add logout test * chore: add reset-password route and tests * chore: remove obsolete comment * chore: add account-page and tests * chore: add data page & first step of the test * chore: add transfer/import data feature and tests * chore: add export and basic test * chore: add all static api routes with tests * Regenerate 'pnpm-lock.json' and fix bad merge conflict WIP: - Tests have been commented out since they dont work - Server doesn't start * easier dev and test runs * - remove --require-pragma from reformat-files so formatting works properly - run pnpm reformat-files over codebase - remove .json files from .eslintignore - add invalid.json file to .eslintignore - configure prettier properly in eslint config - add type jsdoc to prettier config - run adonis generate:manifest command to regenerate ace-manifest.json - specify volta in package.json - introduce typecheck npm script - remove unused .mjs extension from npm scripts - install missing type definition dependencies - add pnpm.allowedDeprecatedVersions to package.json - fix invalid extends in tsconfig.json causing TS issues throughout codebase - remove @ts-ignore throughout codebase which is not relevant anymore - enable some of the tsconfig options - remove outdated eslint-disable from codebase - change deprecated faker.company.companyName() to faker.company.name() - fix TS issues inside transfer.spec.ts * - update to latest node and pnpm versions - upgrade all non-major dependencies to latest - install missing @types/luxon dependency - add cuid to pnpm.allowedDeprecatedVersions - add esModuleInterop config option to tsconfig - migrate more deprecated faker methods to new ones - add more temporary ts-ignore to code * - update eslint config - remove trailingComma: all since default in prettier v3 - add typecheck command to prepare-code npm script - upgrade various dependencies to latest major version - update tsconfig to include only useful config options - disable some lint issues and fix others * - add test command to prepare-code - disable strictPropertyInitialization flag in tsconfig which creates issues with adonis models - update precommit hook to excute pnpm prepare-code - remove ts-ignore statements from all models * fix node and pnpm dependency update * add cross env (so that we can develop on windows) * add signup endpoint (TODO: JWT auth) * Add login endpoint * Add me and updateMe endpoints * Add service endpoint * refactor: change endpoints to use jwt * add recipes endpoint * add workspaces endpoint * fix web controllors for login and post import * Update node deps * Change auth middleware (for web) and exempt api from CSRF * Add import endpoint (franz import) * Fix export/import logic * Fix service and workspace data in user/data * Fix partial lint * chore: workaround lint issues * fix: migration naming had two . * Sync back node with recipes repo * Temporarily ignore typescript * Fix adonisrc to handle public folder static assets * Fix issue with production database * add Legacy Password Provider * Fix lint errors * Fix issue on login errors frontend * add Legacy Password Provider * Fix issue with customIcons * Fix issue with auth tokens * Update 'node' to '18.18.0' * make docker work * improve docker entrypoint (test api performance) * Add migration database script * NODE_ENV on recipes * prefer @ts-expect-error over @ts-ignore * small fixes * Update 'pnpm' to '8.7.6' * fix error catch * Automatically generate JWT Public and Private keys * Use custom Adonis5-jwt * Update code to use secret (old way, no breaking changes) * Normalize appKey * Trick to make JWT tokens on client work with new version * Fix error with new JWT logic * Change migration and how we store JWT * Fix 500 response code (needs to be 401) * Improve logic and fix bugs * Fix build and entrypoint logic * Catch error if appKey changes * Add newToken logic * Fix lint (ignore any errors) * Add build for PRs * pnpm reformat-files result * Fix some tests * Fix reset password not working (test failing) * Restore csrfTokens (disabled by accident) * Fix pnpm start command with .env * Disable failing tests on the transfer endpoint (TODO) * Add tests to PR build * Fix build * Remove unnecessary assertStatus * Add typecheck * hash password on UserFactory (fix build) * Add JWT_USE_PEM true by default (increase security) * fix name of github action --------- Co-authored-by: Vijay A <vraravam@users.noreply.github.com> Co-authored-by: Balaji Vijayakumar <kuttibalaji.v6@gmail.com> Co-authored-by: MCMXC <16797721+mcmxcdev@users.noreply.github.com> Co-authored-by: André Oliveira <oliveira.andrerodrigues95@gmail.com>
Diffstat (limited to 'tests/functional/dashboard/account.spec.ts')
-rw-r--r--tests/functional/dashboard/account.spec.ts124
1 files changed, 124 insertions, 0 deletions
diff --git a/tests/functional/dashboard/account.spec.ts b/tests/functional/dashboard/account.spec.ts
new file mode 100644
index 0000000..bee9d6a
--- /dev/null
+++ b/tests/functional/dashboard/account.spec.ts
@@ -0,0 +1,124 @@
1import { test } from '@japa/runner';
2import User from 'App/Models/User';
3import UserFactory from 'Database/factories/UserFactory';
4
5test.group('Dashboard / Account page', () => {
6 test('redirects to /user/login when accessing /user/account as guest', async ({
7 client,
8 }) => {
9 const response = await client.get('/user/account');
10
11 response.assertRedirectsTo('/user/login'); // Check if it redirects to the expected URL
12 });
13
14 test('returns a 200 opening the account route while logged in', async ({
15 client,
16 }) => {
17 const user = await UserFactory.create();
18 const response = await client.get('/user/account').loginAs(user);
19
20 response.assertStatus(200);
21 response.assertTextIncludes('Your Ferdium account');
22
23 response.assertTextIncludes(user.email);
24 response.assertTextIncludes(user.username);
25 response.assertTextIncludes(user.lastname);
26 });
27
28 test('returns a validation error for all fields when missing', async ({
29 client,
30 }) => {
31 const user = await UserFactory.create();
32 const response = await client.post('/user/account').loginAs(user);
33
34 response.assertTextIncludes(
35 'value="required validation failed,required validation failed" placeholder="E-Mail"',
36 );
37 response.assertTextIncludes(
38 'value="required validation failed,required validation failed" placeholder="Name"',
39 );
40 response.assertTextIncludes(
41 'value="required validation failed,required validation failed" placeholder="Last Name"',
42 );
43 });
44
45 test('returns a validation error for username when there is another user with same username', async ({
46 client,
47 }) => {
48 const user = await UserFactory.create();
49 const existingUser = await UserFactory.create();
50
51 const response = await client.post('/user/account').loginAs(user).form({
52 username: existingUser.username,
53 email: user.email,
54 lastname: user.lastname,
55 });
56
57 response.assertTextIncludes(
58 'value="unique validation failure" placeholder="Name"',
59 );
60 });
61
62 test('returns a validation error for email when there is another user with same email', async ({
63 client,
64 }) => {
65 const user = await UserFactory.create();
66 const existingUser = await UserFactory.create();
67
68 const response = await client.post('/user/account').loginAs(user).form({
69 username: user.username,
70 email: existingUser.email,
71 lastname: user.lastname,
72 });
73
74 response.assertTextIncludes(
75 'value="unique validation failure" placeholder="E-Mail"',
76 );
77 });
78
79 test('updates user data and ensures the data is persisted', async ({
80 client,
81 assert,
82 }) => {
83 const user = await UserFactory.create();
84 const response = await client.post('/user/account').loginAs(user).form({
85 username: 'edited-username',
86 email: 'edited-email',
87 lastname: 'edited-lastname',
88 });
89
90 response.assertStatus(200);
91
92 // Ensure updated data is displayed on account page
93 response.assertTextIncludes('edited-username');
94 response.assertTextIncludes('edited-email');
95 response.assertTextIncludes('edited-lastname');
96
97 // Ensure updated data is persisted in database
98 const updatedUser = await User.findBy('id', user.id);
99 assert.equal(updatedUser?.username, 'edited-username');
100 assert.equal(updatedUser?.email, 'edited-email');
101 assert.equal(updatedUser?.lastname, 'edited-lastname');
102 });
103
104 test('updates user password and ensures the user can still login', async ({
105 client,
106 }) => {
107 const user = await UserFactory.create();
108 const response = await client.post('/user/account').loginAs(user).form({
109 username: user.username,
110 email: user.email,
111 lastname: user.lastname,
112 password: 'modified-password-account-page',
113 });
114
115 response.assertStatus(200);
116
117 const loginResponse = await client.post('/user/login').fields({
118 mail: user.email,
119 password: 'modified-password-account-page',
120 });
121
122 loginResponse.assertRedirectsTo('/user/account');
123 });
124});