chore(tests): fix macos cypress and align with create vite (#2898)
Reviewed-on: https://kolaente.dev/vikunja/frontend/pulls/2898 Reviewed-by: konrad <k@knt.li>
This commit is contained in:
		| @ -96,7 +96,7 @@ steps: | ||||
|       - dependencies | ||||
|  | ||||
|   - name: test-frontend | ||||
|     image: cypress/browsers:node18.12.0-chrome106-ff106 | ||||
|     image: cypress/browsers:node18.12.0-chrome107 | ||||
|     pull: always | ||||
|     environment: | ||||
|       CYPRESS_API_URL: http://api:3456/api/v1 | ||||
| @ -110,8 +110,7 @@ steps: | ||||
|       - sed -i 's/localhost/api/g' dist/index.html | ||||
|       - corepack enable && pnpm config set store-dir .cache/pnpm | ||||
|       - pnpm cypress install | ||||
|       - pnpm run serve:dist & npx wait-on http://localhost:4173 | ||||
|       - pnpm run test:frontend --browser chrome --record | ||||
|       - pnpm run test:e2e-record | ||||
|     depends_on: | ||||
|       - build-prod | ||||
|  | ||||
|  | ||||
							
								
								
									
										34
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										34
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -1,26 +1,31 @@ | ||||
| .DS_Store | ||||
| node_modules | ||||
| /dist* | ||||
| *.zip | ||||
| .direnv/ | ||||
|  | ||||
| # local env files | ||||
| .env.local | ||||
| .env.*.local | ||||
|  | ||||
| # Log files | ||||
| # Logs | ||||
| logs | ||||
| *.log | ||||
| npm-debug.log* | ||||
| yarn-debug.log* | ||||
| yarn-error.log* | ||||
| stats.html | ||||
| pnpm-debug.log* | ||||
| lerna-debug.log* | ||||
| stats.html | ||||
|  | ||||
| node_modules | ||||
| .DS_Store | ||||
| /dist* | ||||
| coverage | ||||
| *.zip | ||||
| .direnv/ | ||||
|  | ||||
| # Test files | ||||
| cypress/screenshots | ||||
| cypress/videos | ||||
|  | ||||
| # local env files | ||||
| .env.local | ||||
| .env.*.local | ||||
|  | ||||
| # Editor directories and files | ||||
| .idea | ||||
| .vscode | ||||
| .idea | ||||
| *.suo | ||||
| *.ntvs* | ||||
| *.njsproj | ||||
| @ -28,9 +33,6 @@ lerna-debug.log* | ||||
| *.sw* | ||||
| !rollup.sw.js | ||||
|  | ||||
| # Test files | ||||
| cypress/screenshots | ||||
| cypress/videos | ||||
|  | ||||
| # Local Netlify folder | ||||
| .netlify | ||||
|  | ||||
| @ -11,8 +11,10 @@ export default defineConfig({ | ||||
| 	}, | ||||
| 	projectId: '181c7x', | ||||
| 	e2e: { | ||||
| 		baseUrl: 'http://localhost:4173', | ||||
| 		specPattern: 'cypress/e2e/**/*.{js,jsx,ts,tsx}', | ||||
| 		specPattern: 'cypress/e2e/**/*.{cy,spec}.{js,jsx,ts,tsx}', | ||||
| 		baseUrl: 'http://127.0.0.1:4173', | ||||
| 		experimentalRunAllSpecs: true, | ||||
| 		// testIsolation: false, | ||||
| 	}, | ||||
| 	component: { | ||||
| 		devServer: { | ||||
|  | ||||
| @ -36,7 +36,7 @@ to get a shell inside the cypress container. | ||||
| In that shell you can then execute the tests with | ||||
|  | ||||
| ```shell | ||||
| pnpm run test:frontend | ||||
| pnpm run test:e2e | ||||
| ``` | ||||
|  | ||||
| ### Using The Cypress Dashboard | ||||
| @ -44,5 +44,5 @@ pnpm run test:frontend | ||||
| To open the Cypress Dashboard and run tests from there, run | ||||
|  | ||||
| ```shell | ||||
| pnpm run cypress:open | ||||
| pnpm run test:e2e:dev | ||||
| ``` | ||||
|  | ||||
| @ -9,7 +9,7 @@ services: | ||||
|     ports: | ||||
|       - 3456:3456 | ||||
|   cypress: | ||||
|     image: cypress/browsers:node16.14.0-chrome99-ff97 | ||||
|     image: cypress/browsers:node18.12.0-chrome107 | ||||
|     volumes: | ||||
|     - ..:/project | ||||
|     - $HOME/.cache:/home/node/.cache/ | ||||
|  | ||||
| @ -1,9 +1,10 @@ | ||||
| import {ListFactory} from '../../factories/list' | ||||
| import {createFakeUserAndLogin} from '../../support/authenticateUser' | ||||
|  | ||||
| import '../../support/authenticateUser' | ||||
| import {ListFactory} from '../../factories/list' | ||||
| import {prepareLists} from './prepareLists' | ||||
|  | ||||
| describe('List History', () => { | ||||
| 	createFakeUserAndLogin() | ||||
| 	prepareLists() | ||||
| 	 | ||||
| 	it('should show a list history on the home page', () => { | ||||
|  | ||||
| @ -1,10 +1,12 @@ | ||||
| import {formatISO, format} from 'date-fns' | ||||
|  | ||||
| import {createFakeUserAndLogin} from '../../support/authenticateUser' | ||||
|  | ||||
| import {TaskFactory} from '../../factories/task' | ||||
| import {prepareLists} from './prepareLists' | ||||
|  | ||||
| import '../../support/authenticateUser' | ||||
|  | ||||
| describe('List View Gantt', () => { | ||||
| 	createFakeUserAndLogin() | ||||
| 	prepareLists() | ||||
|  | ||||
| 	it('Hides tasks with no dates', () => { | ||||
| @ -33,8 +35,8 @@ describe('List View Gantt', () => { | ||||
| 	it('Shows tasks with dates', () => { | ||||
| 		const now = new Date() | ||||
| 		const tasks = TaskFactory.create(1, { | ||||
| 			start_date: formatISO(now), | ||||
| 			end_date: formatISO(now.setDate(now.getDate() + 4)), | ||||
| 			start_date: now.toISOString(), | ||||
| 			end_date: new Date(new Date(now).setDate(now.getDate() + 4)).toISOString(), | ||||
| 		}) | ||||
| 		cy.visit('/lists/1/gantt') | ||||
|  | ||||
|  | ||||
| @ -1,14 +1,15 @@ | ||||
| import {createFakeUserAndLogin} from '../../support/authenticateUser' | ||||
|  | ||||
| import {BucketFactory} from '../../factories/bucket' | ||||
| import {ListFactory} from '../../factories/list' | ||||
| import {TaskFactory} from '../../factories/task' | ||||
| import {prepareLists} from './prepareLists' | ||||
|  | ||||
| import '../../support/authenticateUser' | ||||
|  | ||||
| describe('List View Kanban', () => { | ||||
| 	let buckets | ||||
| 	createFakeUserAndLogin() | ||||
| 	prepareLists() | ||||
|  | ||||
| 	 | ||||
| 	let buckets | ||||
| 	beforeEach(() => { | ||||
| 		buckets = BucketFactory.create(2) | ||||
| 	}) | ||||
| @ -38,7 +39,7 @@ describe('List View Kanban', () => { | ||||
| 		}) | ||||
| 		cy.visit('/lists/1/kanban') | ||||
|  | ||||
| 		cy.getSettled('.kanban .bucket') | ||||
| 		cy.get('.kanban .bucket') | ||||
| 			.contains(buckets[0].title) | ||||
| 			.get('.bucket-footer .button') | ||||
| 			.contains('Add another task') | ||||
| @ -70,7 +71,7 @@ describe('List View Kanban', () => { | ||||
| 	it('Can set a bucket limit', () => { | ||||
| 		cy.visit('/lists/1/kanban') | ||||
|  | ||||
| 		cy.getSettled('.kanban .bucket .bucket-header .dropdown.options .dropdown-trigger') | ||||
| 		cy.get('.kanban .bucket .bucket-header .dropdown.options .dropdown-trigger') | ||||
| 			.first() | ||||
| 			.click() | ||||
| 		cy.get('.kanban .bucket .bucket-header .dropdown.options .dropdown-menu .dropdown-item') | ||||
| @ -91,7 +92,7 @@ describe('List View Kanban', () => { | ||||
| 	it('Can rename a bucket', () => { | ||||
| 		cy.visit('/lists/1/kanban') | ||||
|  | ||||
| 		cy.getSettled('.kanban .bucket .bucket-header .title') | ||||
| 		cy.get('.kanban .bucket .bucket-header .title') | ||||
| 			.first() | ||||
| 			.type('{selectall}New Bucket Title{enter}') | ||||
| 		cy.get('.kanban .bucket .bucket-header .title') | ||||
| @ -102,7 +103,7 @@ describe('List View Kanban', () => { | ||||
| 	it('Can delete a bucket', () => { | ||||
| 		cy.visit('/lists/1/kanban') | ||||
|  | ||||
| 		cy.getSettled('.kanban .bucket .bucket-header .dropdown.options .dropdown-trigger') | ||||
| 		cy.get('.kanban .bucket .bucket-header .dropdown.options .dropdown-trigger') | ||||
| 			.first() | ||||
| 			.click() | ||||
| 		cy.get('.kanban .bucket .bucket-header .dropdown.options .dropdown-menu .dropdown-item') | ||||
| @ -129,7 +130,7 @@ describe('List View Kanban', () => { | ||||
| 		}) | ||||
| 		cy.visit('/lists/1/kanban') | ||||
|  | ||||
| 		cy.getSettled('.kanban .bucket .tasks .task') | ||||
| 		cy.get('.kanban .bucket .tasks .task') | ||||
| 			.contains(tasks[0].title) | ||||
| 			.first() | ||||
| 			.drag('.kanban .bucket:nth-child(2) .tasks') | ||||
| @ -148,7 +149,7 @@ describe('List View Kanban', () => { | ||||
| 		}) | ||||
| 		cy.visit('/lists/1/kanban') | ||||
|  | ||||
| 		cy.getSettled('.kanban .bucket .tasks .task') | ||||
| 		cy.get('.kanban .bucket .tasks .task') | ||||
| 			.contains(tasks[0].title) | ||||
| 			.should('be.visible') | ||||
| 			.click() | ||||
| @ -170,7 +171,7 @@ describe('List View Kanban', () => { | ||||
| 		const task = tasks[0] | ||||
| 		cy.visit('/lists/1/kanban') | ||||
|  | ||||
| 		cy.getSettled('.kanban .bucket .tasks .task') | ||||
| 		cy.get('.kanban .bucket .tasks .task') | ||||
| 			.contains(task.title) | ||||
| 			.should('be.visible') | ||||
| 			.click() | ||||
| @ -217,7 +218,7 @@ describe('List View Kanban', () => { | ||||
| 		const task = tasks[0] | ||||
| 		cy.visit('/lists/1/kanban') | ||||
|  | ||||
| 		cy.getSettled('.kanban .bucket .tasks .task') | ||||
| 		cy.get('.kanban .bucket .tasks .task') | ||||
| 			.contains(task.title) | ||||
| 			.should('be.visible') | ||||
| 			.click() | ||||
| @ -234,7 +235,7 @@ describe('List View Kanban', () => { | ||||
| 		cy.get('.global-notification') | ||||
| 			.should('contain', 'Success') | ||||
| 		 | ||||
| 		cy.getSettled('.kanban .bucket .tasks') | ||||
| 		cy.get('.kanban .bucket .tasks') | ||||
| 			.should('not.contain', task.title) | ||||
| 	}) | ||||
| }) | ||||
| @ -1,12 +1,13 @@ | ||||
| import {createFakeUserAndLogin} from '../../support/authenticateUser' | ||||
|  | ||||
| import {UserListFactory} from '../../factories/users_list' | ||||
| import {TaskFactory} from '../../factories/task' | ||||
| import {UserFactory} from '../../factories/user' | ||||
| import {ListFactory} from '../../factories/list' | ||||
| import {prepareLists} from './prepareLists' | ||||
|  | ||||
| import '../../support/authenticateUser' | ||||
|  | ||||
| describe('List View List', () => { | ||||
| 	createFakeUserAndLogin() | ||||
| 	prepareLists() | ||||
|  | ||||
| 	it('Should be an empty list', () => { | ||||
|  | ||||
| @ -1,8 +1,10 @@ | ||||
| import {createFakeUserAndLogin} from '../../support/authenticateUser' | ||||
|  | ||||
| import {TaskFactory} from '../../factories/task' | ||||
|  | ||||
| import '../../support/authenticateUser' | ||||
|  | ||||
| describe('List View Table', () => { | ||||
| 	createFakeUserAndLogin() | ||||
|  | ||||
| 	it('Should show a table with tasks', () => { | ||||
| 		const tasks = TaskFactory.create(1) | ||||
| 		cy.visit('/lists/1/table') | ||||
|  | ||||
| @ -1,9 +1,11 @@ | ||||
| import {createFakeUserAndLogin} from '../../support/authenticateUser' | ||||
|  | ||||
| import {TaskFactory} from '../../factories/task' | ||||
| import {prepareLists} from './prepareLists' | ||||
|  | ||||
| import '../../support/authenticateUser' | ||||
|  | ||||
| describe('Lists', () => { | ||||
| 	createFakeUserAndLogin() | ||||
|  | ||||
| 	let lists | ||||
| 	prepareLists((newLists) => (lists = newLists)) | ||||
|  | ||||
|  | ||||
| @ -1,14 +1,14 @@ | ||||
| import {UserFactory} from '../../factories/user' | ||||
| import {createFakeUserAndLogin} from '../../support/authenticateUser' | ||||
|  | ||||
| import '../../support/authenticateUser' | ||||
| import {ListFactory} from '../../factories/list' | ||||
| import {NamespaceFactory} from '../../factories/namespace' | ||||
|  | ||||
| describe('Namepaces', () => { | ||||
| 	createFakeUserAndLogin() | ||||
|  | ||||
| 	let namespaces | ||||
|  | ||||
| 	beforeEach(() => { | ||||
| 		UserFactory.create(1) | ||||
| 		namespaces = NamespaceFactory.create(1) | ||||
| 		ListFactory.create(1) | ||||
| 	}) | ||||
|  | ||||
| @ -1,10 +1,8 @@ | ||||
| import {ListFactory} from '../../factories/list' | ||||
| import {UserFactory} from '../../factories/user' | ||||
| import {NamespaceFactory} from '../../factories/namespace' | ||||
| import {TaskFactory} from '../../factories/task' | ||||
|  | ||||
| export function createLists() { | ||||
| 	UserFactory.create(1) | ||||
| 	NamespaceFactory.create(1) | ||||
| 	const lists = ListFactory.create(1, { | ||||
| 		title: 'First List' | ||||
|  | ||||
| @ -1,14 +1,16 @@ | ||||
| import {createFakeUserAndLogin} from '../../support/authenticateUser' | ||||
|  | ||||
| import {TaskFactory} from '../../factories/task' | ||||
| import {ListFactory} from '../../factories/list' | ||||
| import {NamespaceFactory} from '../../factories/namespace' | ||||
| import {UserListFactory} from '../../factories/users_list' | ||||
|  | ||||
| import '../../support/authenticateUser' | ||||
|  | ||||
| describe('Editor', () => { | ||||
| 	createFakeUserAndLogin() | ||||
| 	 | ||||
| 	beforeEach(() => { | ||||
| 		NamespaceFactory.create(1) | ||||
| 		const lists = ListFactory.create(1) | ||||
| 		ListFactory.create(1) | ||||
| 		TaskFactory.truncate() | ||||
| 		UserListFactory.truncate() | ||||
| 	}) | ||||
|  | ||||
| @ -1,6 +1,12 @@ | ||||
| import '../../support/authenticateUser' | ||||
| import {createFakeUserAndLogin} from '../../support/authenticateUser' | ||||
|  | ||||
| describe('The Menu', () => { | ||||
| 	createFakeUserAndLogin() | ||||
|  | ||||
| 	beforeEach(() => { | ||||
| 		cy.visit('/') | ||||
| 	}) | ||||
|  | ||||
| 	it('Is visible by default on desktop', () => { | ||||
| 		cy.get('.namespace-container') | ||||
| 			.should('have.class', 'is-active') | ||||
|  | ||||
| @ -1,9 +1,12 @@ | ||||
| import {createFakeUserAndLogin} from '../../support/authenticateUser' | ||||
|  | ||||
| import {TeamFactory} from '../../factories/team' | ||||
| import {TeamMemberFactory} from '../../factories/team_member' | ||||
| import {UserFactory} from '../../factories/user' | ||||
| import '../../support/authenticateUser' | ||||
|  | ||||
| describe('Team', () => { | ||||
| 	createFakeUserAndLogin() | ||||
|  | ||||
|     it('Creates a new team', () => { | ||||
|         TeamFactory.truncate() | ||||
|         cy.visit('/teams') | ||||
|  | ||||
| @ -1,16 +1,13 @@ | ||||
| import {createFakeUserAndLogin} from '../../support/authenticateUser' | ||||
|  | ||||
| import {ListFactory} from '../../factories/list' | ||||
| import {seed} from '../../support/seed' | ||||
| import {TaskFactory} from '../../factories/task' | ||||
| import {formatISO} from 'date-fns' | ||||
| import {UserFactory} from '../../factories/user' | ||||
| import {NamespaceFactory} from '../../factories/namespace' | ||||
| import {BucketFactory} from '../../factories/bucket' | ||||
| import {updateUserSettings} from '../../support/updateUserSettings' | ||||
|  | ||||
| import '../../support/authenticateUser' | ||||
|  | ||||
| function seedTasks(numberOfTasks = 100, startDueDate = new Date()) { | ||||
| 	UserFactory.create(1) | ||||
| function seedTasks(numberOfTasks = 50, startDueDate = new Date()) { | ||||
| 	NamespaceFactory.create(1) | ||||
| 	const list = ListFactory.create()[0] | ||||
| 	BucketFactory.create(1, { | ||||
| @ -20,7 +17,7 @@ function seedTasks(numberOfTasks = 100, startDueDate = new Date()) { | ||||
| 	let dueDate = startDueDate | ||||
| 	for (let i = 0; i < numberOfTasks; i++) { | ||||
| 		const now = new Date() | ||||
| 		dueDate = (new Date(dueDate.valueOf())).setDate((new Date(dueDate.valueOf())).getDate() + 2) | ||||
| 		dueDate = new Date(new Date(dueDate).setDate(dueDate.getDate() + 2)) | ||||
| 		tasks.push({ | ||||
| 			id: i + 1, | ||||
| 			list_id: list.id, | ||||
| @ -28,9 +25,9 @@ function seedTasks(numberOfTasks = 100, startDueDate = new Date()) { | ||||
| 			created_by_id: 1, | ||||
| 			title: 'Test Task ' + i, | ||||
| 			index: i + 1, | ||||
| 			due_date: formatISO(dueDate), | ||||
| 			created: formatISO(now), | ||||
| 			updated: formatISO(now), | ||||
| 			due_date: dueDate.toISOString(), | ||||
| 			created: now.toISOString(), | ||||
| 			updated: now.toISOString(), | ||||
| 		}) | ||||
| 	} | ||||
| 	seed(TaskFactory.table, tasks) | ||||
| @ -38,8 +35,11 @@ function seedTasks(numberOfTasks = 100, startDueDate = new Date()) { | ||||
| } | ||||
|  | ||||
| describe('Home Page Task Overview', () => { | ||||
| 	createFakeUserAndLogin() | ||||
|  | ||||
| 	it('Should show tasks with a near due date first on the home page overview', () => { | ||||
| 		const {tasks} = seedTasks() | ||||
| 		const taskCount = 50 | ||||
| 		const {tasks} = seedTasks(taskCount) | ||||
|  | ||||
| 		cy.visit('/') | ||||
| 		cy.get('[data-cy="showTasks"] .card .task') | ||||
| @ -49,8 +49,10 @@ describe('Home Page Task Overview', () => { | ||||
| 	}) | ||||
|  | ||||
| 	it('Should show overdue tasks first, then show other tasks', () => { | ||||
| 		const oldDate = (new Date()).setDate((new Date()).getDate() - 14) | ||||
| 		const {tasks} = seedTasks(100, oldDate) | ||||
| 		const now = new Date() | ||||
| 		const oldDate = new Date(new Date(now).setDate(now.getDate() - 14)) | ||||
| 		const taskCount = 50 | ||||
| 		const {tasks} = seedTasks(taskCount, oldDate) | ||||
|  | ||||
| 		cy.visit('/') | ||||
| 		cy.get('[data-cy="showTasks"] .card .task') | ||||
| @ -68,7 +70,7 @@ describe('Home Page Task Overview', () => { | ||||
| 		TaskFactory.create(1, { | ||||
| 			id: 999, | ||||
| 			title: newTaskTitle, | ||||
| 			due_date: formatISO(new Date()), | ||||
| 			due_date: new Date().toISOString(), | ||||
| 		}, false) | ||||
| 		 | ||||
| 		cy.visit(`/lists/${tasks[0].list_id}/list`) | ||||
| @ -83,7 +85,7 @@ describe('Home Page Task Overview', () => { | ||||
| 	 | ||||
| 	it('Should not show a new task without a date at the bottom when there are > 50 tasks', () => { | ||||
| 		// We're not using the api here to create the task in order to verify the flow | ||||
| 		const {tasks} = seedTasks() | ||||
| 		const {tasks} = seedTasks(100) | ||||
| 		const newTaskTitle = 'New Task' | ||||
|  | ||||
| 		cy.visit('/') | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| import {formatISO} from 'date-fns' | ||||
| import {createFakeUserAndLogin} from '../../support/authenticateUser' | ||||
|  | ||||
| import {TaskFactory} from '../../factories/task' | ||||
| import {ListFactory} from '../../factories/list' | ||||
| @ -11,7 +11,6 @@ import {LabelFactory} from '../../factories/labels' | ||||
| import {LabelTaskFactory} from '../../factories/label_task' | ||||
| import {BucketFactory} from '../../factories/bucket' | ||||
|  | ||||
| import '../../support/authenticateUser' | ||||
| import {TaskAttachmentFactory} from '../../factories/task_attachments' | ||||
|  | ||||
| function addLabelToTaskAndVerify(labelTitle: string) { | ||||
| @ -46,12 +45,14 @@ function uploadAttachmentAndVerify(taskId: number) { | ||||
| } | ||||
|  | ||||
| describe('Task', () => { | ||||
| 	createFakeUserAndLogin() | ||||
|  | ||||
| 	let namespaces | ||||
| 	let lists | ||||
| 	let buckets | ||||
|  | ||||
| 	beforeEach(() => { | ||||
| 		UserFactory.create(1) | ||||
| 		// UserFactory.create(1) | ||||
| 		namespaces = NamespaceFactory.create(1) | ||||
| 		lists = ListFactory.create(1) | ||||
| 		buckets = BucketFactory.create(1, { | ||||
| @ -145,7 +146,7 @@ describe('Task', () => { | ||||
| 				id: 1, | ||||
| 				index: 1, | ||||
| 				done: true, | ||||
| 				done_at: formatISO(new Date()) | ||||
| 				done_at: new Date().toISOString() | ||||
| 			}) | ||||
| 			cy.visit(`/tasks/${tasks[0].id}`) | ||||
|  | ||||
| @ -421,10 +422,10 @@ describe('Task', () => { | ||||
|  | ||||
| 			cy.visit(`/tasks/${tasks[0].id}`) | ||||
|  | ||||
| 			cy.getSettled('.task-view .details.labels-list .multiselect .input-wrapper') | ||||
| 			cy.get('.task-view .details.labels-list .multiselect .input-wrapper') | ||||
| 				.should('be.visible') | ||||
| 				.should('contain', labels[0].title) | ||||
| 			cy.getSettled('.task-view .details.labels-list .multiselect .input-wrapper') | ||||
| 			cy.get('.task-view .details.labels-list .multiselect .input-wrapper') | ||||
| 				.children() | ||||
| 				.first() | ||||
| 				.get('[data-cy="taskDetail.removeLabel"]') | ||||
|  | ||||
							
								
								
									
										11
									
								
								cypress/e2e/tsconfig.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								cypress/e2e/tsconfig.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| { | ||||
|   "extends": "@vue/tsconfig/tsconfig.web.json", | ||||
|   "include": ["./**/*", "../support/**/*", "../factories/**/*"], | ||||
|   "compilerOptions": { | ||||
|     "baseUrl": ".", | ||||
|     "isolatedModules": false, | ||||
|     "target": "ES2015", | ||||
|     "lib": ["ESNext", "dom"], | ||||
|     "types": ["cypress"] | ||||
|   } | ||||
| } | ||||
| @ -11,16 +11,11 @@ const testAndAssertFailed = fixture => { | ||||
| 	cy.get('div.message.danger').contains('Wrong username or password.') | ||||
| } | ||||
|  | ||||
| const username = 'test' | ||||
|  | ||||
| context('Login', () => { | ||||
| 	beforeEach(() => { | ||||
| 		UserFactory.create(1, { | ||||
| 			username: 'test', | ||||
| 		}) | ||||
| 		cy.visit('/', { | ||||
| 			onBeforeLoad(win) { | ||||
| 				win.localStorage.removeItem('token') | ||||
| 			}, | ||||
| 		}) | ||||
| 		UserFactory.create(1, {username}) | ||||
| 	}) | ||||
|  | ||||
| 	it('Should log in with the right credentials', () => { | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| import '../../support/authenticateUser' | ||||
| import {createFakeUserAndLogin} from '../../support/authenticateUser' | ||||
| import {createLists} from '../list/prepareLists' | ||||
|  | ||||
| function logout() { | ||||
| @ -10,6 +10,8 @@ function logout() { | ||||
| } | ||||
|  | ||||
| describe('Log out', () => { | ||||
| 	createFakeUserAndLogin() | ||||
|  | ||||
| 	it('Logs the user out', () => { | ||||
| 		cy.visit('/') | ||||
|  | ||||
|  | ||||
| @ -1,11 +1,7 @@ | ||||
| import {UserFactory} from '../../factories/user' | ||||
|  | ||||
| import '../../support/authenticateUser' | ||||
| import {createFakeUserAndLogin} from '../../support/authenticateUser' | ||||
|  | ||||
| describe('User Settings', () => { | ||||
| 	beforeEach(() => { | ||||
| 		UserFactory.create(1) | ||||
| 	}) | ||||
| 	createFakeUserAndLogin() | ||||
|  | ||||
| 	it('Changes the user avatar', () => { | ||||
| 		cy.intercept(`${Cypress.env('API_URL')}/user/settings/avatar/upload`).as('uploadAvatar') | ||||
|  | ||||
| @ -1,6 +1,5 @@ | ||||
| import {faker} from '@faker-js/faker' | ||||
| import {Factory} from '../support/factory' | ||||
| import {formatISO} from 'date-fns' | ||||
|  | ||||
| export class BucketFactory extends Factory { | ||||
| 	static table = 'buckets' | ||||
| @ -13,8 +12,8 @@ export class BucketFactory extends Factory { | ||||
| 			title: faker.lorem.words(3), | ||||
| 			list_id: 1, | ||||
| 			created_by_id: 1, | ||||
| 			created: formatISO(now), | ||||
| 			updated: formatISO(now) | ||||
| 			created: now.toISOString(), | ||||
| 			updated: now.toISOString(), | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| @ -1,5 +1,4 @@ | ||||
| import {Factory} from '../support/factory' | ||||
| import {formatISO} from 'date-fns' | ||||
|  | ||||
| export class LabelTaskFactory extends Factory { | ||||
| 	static table = 'label_tasks' | ||||
| @ -11,7 +10,7 @@ export class LabelTaskFactory extends Factory { | ||||
| 			id: '{increment}', | ||||
| 			task_id: 1, | ||||
| 			label_id: 1, | ||||
| 			created: formatISO(now), | ||||
| 			created: now.toISOString(), | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @ -1,7 +1,6 @@ | ||||
| import {faker} from '@faker-js/faker' | ||||
|  | ||||
| import {Factory} from '../support/factory' | ||||
| import {formatISO} from 'date-fns' | ||||
|  | ||||
| export class LabelFactory extends Factory { | ||||
| 	static table = 'labels' | ||||
| @ -15,8 +14,8 @@ export class LabelFactory extends Factory { | ||||
| 			description: faker.lorem.text(10), | ||||
| 			hex_color: (Math.random()*0xFFFFFF<<0).toString(16), // random 6-digit hex number | ||||
| 			created_by_id: 1, | ||||
| 			created: formatISO(now), | ||||
| 			updated: formatISO(now), | ||||
| 			created: now.toISOString(), | ||||
| 			updated: now.toISOString(), | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @ -1,5 +1,4 @@ | ||||
| import {Factory} from '../support/factory' | ||||
| import {formatISO} from "date-fns" | ||||
| import {faker} from '@faker-js/faker' | ||||
|  | ||||
| export class LinkShareFactory extends Factory { | ||||
| @ -15,8 +14,8 @@ export class LinkShareFactory extends Factory { | ||||
| 			right: 0, | ||||
| 			sharing_type: 0, | ||||
| 			shared_by_id: 1, | ||||
| 			created: formatISO(now), | ||||
| 			updated: formatISO(now) | ||||
| 			created: now.toISOString(), | ||||
| 			updated: now.toISOString(), | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| @ -1,5 +1,4 @@ | ||||
| import {Factory} from '../support/factory' | ||||
| import {formatISO} from "date-fns" | ||||
| import {faker} from '@faker-js/faker' | ||||
|  | ||||
| export class ListFactory extends Factory { | ||||
| @ -13,8 +12,8 @@ export class ListFactory extends Factory { | ||||
| 			title: faker.lorem.words(3), | ||||
| 			owner_id: 1, | ||||
| 			namespace_id: 1, | ||||
| 			created: formatISO(now), | ||||
| 			updated: formatISO(now) | ||||
| 			created: now.toISOString(), | ||||
| 			updated: now.toISOString(), | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @ -1,6 +1,5 @@ | ||||
| import {faker} from '@faker-js/faker' | ||||
| import {Factory} from '../support/factory' | ||||
| import {formatISO} from 'date-fns' | ||||
|  | ||||
| export class NamespaceFactory extends Factory { | ||||
| 	static table = 'namespaces' | ||||
| @ -12,8 +11,8 @@ export class NamespaceFactory extends Factory { | ||||
| 			id: '{increment}', | ||||
| 			title: faker.lorem.words(3), | ||||
| 			owner_id: 1, | ||||
| 			created: formatISO(now), | ||||
| 			updated: formatISO(now) | ||||
| 			created: now.toISOString(), | ||||
| 			updated: now.toISOString(), | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| @ -1,6 +1,5 @@ | ||||
| import {faker} from '@faker-js/faker' | ||||
| import {Factory} from '../support/factory' | ||||
| import {formatISO} from 'date-fns' | ||||
|  | ||||
| export class TaskFactory extends Factory { | ||||
| 	static table = 'tasks' | ||||
| @ -16,8 +15,8 @@ export class TaskFactory extends Factory { | ||||
| 			created_by_id: 1, | ||||
| 			index: '{increment}', | ||||
| 			position: '{increment}', | ||||
| 			created: formatISO(now), | ||||
| 			updated: formatISO(now) | ||||
| 			created: now.toISOString(), | ||||
| 			updated: now.toISOString() | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| @ -1,5 +1,4 @@ | ||||
| import {Factory} from '../support/factory' | ||||
| import {formatISO} from 'date-fns' | ||||
|  | ||||
| export class TaskAssigneeFactory extends Factory { | ||||
| 	static table = 'task_assignees' | ||||
| @ -11,7 +10,7 @@ export class TaskAssigneeFactory extends Factory { | ||||
| 			id: '{increment}', | ||||
| 			task_id: 1, | ||||
| 			user_id: 1, | ||||
| 			created: formatISO(now), | ||||
| 			created: now.toISOString(), | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @ -1,5 +1,4 @@ | ||||
| import {Factory} from '../support/factory' | ||||
| import {formatISO} from 'date-fns' | ||||
|  | ||||
| export class TaskAttachmentFactory extends Factory { | ||||
| 	static table = 'task_attachments' | ||||
| @ -11,7 +10,7 @@ export class TaskAttachmentFactory extends Factory { | ||||
| 			id: '{increment}', | ||||
| 			task_id: 1, | ||||
| 			file_id: 1, | ||||
| 			created: formatISO(now), | ||||
| 			created: now.toISOString(), | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @ -1,7 +1,6 @@ | ||||
| import {faker} from '@faker-js/faker' | ||||
|  | ||||
| import {Factory} from '../support/factory' | ||||
| import {formatISO} from "date-fns" | ||||
|  | ||||
| export class TaskCommentFactory extends Factory { | ||||
| 	static table = 'task_comments' | ||||
| @ -14,8 +13,8 @@ export class TaskCommentFactory extends Factory { | ||||
| 			comment: faker.lorem.text(3), | ||||
| 			author_id: 1, | ||||
| 			task_id: 1, | ||||
| 			created: formatISO(now), | ||||
| 			updated: formatISO(now) | ||||
| 			created: now.toISOString(), | ||||
| 			updated: now.toISOString() | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| @ -1,6 +1,5 @@ | ||||
| import {faker} from '@faker-js/faker' | ||||
| import {Factory} from '../support/factory' | ||||
| import {formatISO} from 'date-fns' | ||||
|  | ||||
| export class TeamFactory extends Factory { | ||||
|     static table = 'teams' | ||||
| @ -11,8 +10,8 @@ export class TeamFactory extends Factory { | ||||
|         return { | ||||
|             name: faker.lorem.words(3), | ||||
|             created_by_id: 1, | ||||
| 			created: formatISO(now), | ||||
| 			updated: formatISO(now) | ||||
| 			created: now.toISOString(), | ||||
| 			updated: now.toISOString(), | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -1,5 +1,4 @@ | ||||
| import {Factory} from '../support/factory' | ||||
| import {formatISO} from 'date-fns' | ||||
|  | ||||
| export class TeamMemberFactory extends Factory { | ||||
|     static table = 'team_members' | ||||
| @ -9,7 +8,7 @@ export class TeamMemberFactory extends Factory { | ||||
|             team_id: 1, | ||||
|             user_id: 1, | ||||
|             admin: false, | ||||
|             created: formatISO(new Date()), | ||||
|             created: new Date().toISOString(), | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @ -1,7 +1,6 @@ | ||||
| import {faker} from '@faker-js/faker' | ||||
|  | ||||
| import {Factory} from '../support/factory' | ||||
| import {formatISO} from "date-fns" | ||||
|  | ||||
| export class UserFactory extends Factory { | ||||
| 	static table = 'users' | ||||
| @ -15,8 +14,8 @@ export class UserFactory extends Factory { | ||||
|             password: '$2a$14$dcadBoMBL9jQoOcZK8Fju.cy0Ptx2oZECkKLnaa8ekRoTFe1w7To.', // 1234 | ||||
| 			status: 0, | ||||
| 			issuer: 'local', | ||||
| 			created: formatISO(now), | ||||
| 			updated: formatISO(now) | ||||
| 			created: now.toISOString(), | ||||
| 			updated: now.toISOString(), | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @ -1,5 +1,4 @@ | ||||
| import {Factory} from '../support/factory' | ||||
| import {formatISO} from "date-fns" | ||||
|  | ||||
| export class UserListFactory extends Factory { | ||||
| 	static table = 'users_lists' | ||||
| @ -12,8 +11,8 @@ export class UserListFactory extends Factory { | ||||
| 			list_id: 1, | ||||
| 			user_id: 1, | ||||
| 			right: 0, | ||||
| 			created: formatISO(now), | ||||
| 			updated: formatISO(now) | ||||
| 			created: now.toISOString(), | ||||
| 			updated: now.toISOString(), | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @ -4,26 +4,32 @@ | ||||
|  | ||||
| import {UserFactory} from '../factories/user' | ||||
|  | ||||
| let token | ||||
|  | ||||
| before(() => { | ||||
| 	const users = UserFactory.create(1) | ||||
|  | ||||
| 	cy.request('POST', `${Cypress.env('API_URL')}/login`, { | ||||
| 		username: users[0].username, | ||||
| 		password: '1234', | ||||
| 	}) | ||||
| 		.its('body') | ||||
| 		.then(r => { | ||||
| 			token = r.token | ||||
| export function login(user, cacheAcrossSpecs = false) { | ||||
| 	if (!user) { | ||||
| 		throw new Error('Needs user') | ||||
| 	} | ||||
| 	// Caching session when logging in via page visit | ||||
| 	cy.session(`user__${user.username}`, () => { | ||||
| 		cy.request('POST', `${Cypress.env('API_URL')}/login`, { | ||||
| 			username: user.username, | ||||
| 			password: '1234', | ||||
| 		}).then(({ body }) => { | ||||
| 			window.localStorage.setItem('token', body.token) | ||||
| 		}) | ||||
| }) | ||||
| 	}, { | ||||
|     cacheAcrossSpecs, | ||||
|   }) | ||||
| } | ||||
|  | ||||
| beforeEach(() => { | ||||
| 	cy.log(`Using token ${token} to make authenticated requests`) | ||||
| 	cy.visit('/', { | ||||
| 		onBeforeLoad(win) { | ||||
| 			win.localStorage.setItem('token', token) | ||||
| 		}, | ||||
| export function createFakeUserAndLogin() { | ||||
| 	let user | ||||
| 	before(() => { | ||||
| 		user = UserFactory.create(1)[0] | ||||
| 	}) | ||||
| }) | ||||
|  | ||||
| 	beforeEach(() => { | ||||
| 		login(user, true) | ||||
| 	}) | ||||
|  | ||||
| 	return user | ||||
| } | ||||
| @ -34,38 +34,4 @@ | ||||
| //       visit(originalFn: CommandOriginalFn, url: string, options: Partial<VisitOptions>): Chainable<Element> | ||||
| //     } | ||||
| //   } | ||||
| // } | ||||
|  | ||||
| /** | ||||
|  * Recursively gets an element, returning only after it's determined to be attached to the DOM for good. | ||||
|  * | ||||
|  * Source: https://github.com/cypress-io/cypress/issues/7306#issuecomment-850621378 | ||||
|  */ | ||||
| Cypress.Commands.add('getSettled', (selector, opts = {}) => { | ||||
| 	const retries = opts.retries || 3 | ||||
| 	const delay = opts.delay || 100 | ||||
|  | ||||
| 	const isAttached = (resolve, count = 0) => { | ||||
| 		const el = Cypress.$(selector) | ||||
|  | ||||
| 		// is element attached to the DOM? | ||||
| 		count = Cypress.dom.isAttached(el) ? count + 1 : 0 | ||||
|  | ||||
| 		// hit our base case, return the element | ||||
| 		if (count >= retries) { | ||||
| 			return resolve(el) | ||||
| 		} | ||||
|  | ||||
| 		// retry after a bit of a delay | ||||
| 		setTimeout(() => isAttached(resolve, count), delay) | ||||
| 	} | ||||
|  | ||||
| 	// wrap, so we can chain cypress commands off the result | ||||
| 	return cy.wrap(null).then(() => { | ||||
| 		return new Cypress.Promise((resolve) => { | ||||
| 			return isAttached(resolve, 0) | ||||
| 		}).then((el) => { | ||||
| 			return cy.wrap(el) | ||||
| 		}) | ||||
| 	}) | ||||
| }) | ||||
| // } | ||||
| @ -1,10 +0,0 @@ | ||||
| { | ||||
|   "extends": "@vue/tsconfig/tsconfig.web.json", | ||||
|   "include": ["./integration/**/*", "./support/**/*"], | ||||
|   "compilerOptions": { | ||||
|     "isolatedModules": false, | ||||
|     "target": "es5", | ||||
|     "lib": ["es5", "dom"], | ||||
|     "types": ["cypress"] | ||||
|   } | ||||
| } | ||||
							
								
								
									
										14
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								package.json
									
									
									
									
									
								
							| @ -4,16 +4,17 @@ | ||||
|   "private": true, | ||||
|   "scripts": { | ||||
|     "serve": "vite", | ||||
|     "serve:dist": "vite preview --port 4173", | ||||
|     "serve:dist:dev": "vite preview --mode development --port 4173", | ||||
|     "preview": "vite preview --port 4173", | ||||
|     "preview:dev": "vite preview --outDir dist-dev --mode development --port 4173", | ||||
|     "build": "vite build && workbox copyLibraries dist/", | ||||
|     "build:modern-only": "BUILD_MODERN_ONLY=true vite build && workbox copyLibraries dist/", | ||||
|     "build:dev": "vite build --mode development --outDir dist-dev/", | ||||
|     "lint": "eslint --ignore-pattern '*.test.*' ./src --ext .vue,.js,.ts", | ||||
|     "cypress:open": "cypress open", | ||||
|     "test:unit": "vitest --run", | ||||
|     "test:unit-watch": "vitest watch", | ||||
|     "test:frontend": "cypress run", | ||||
|     "test:e2e": "start-server-and-test preview http://127.0.0.1:4173 'cypress run --e2e --browser chrome'", | ||||
|     "test:e2e-record": "start-server-and-test preview http://127.0.0.1:4173 'cypress run --e2e --browser chrome --record'", | ||||
|     "test:e2e-dev-dev": "start-server-and-test preview:dev http://127.0.0.1:4173 'cypress open --e2e'", | ||||
|     "test:e2e-dev": "start-server-and-test preview http://127.0.0.1:4173 'cypress open --e2e'", | ||||
|     "test:unit": "vitest", | ||||
|     "typecheck": "vue-tsc --noEmit && vue-tsc --noEmit -p tsconfig.vitest.json --composite false", | ||||
|     "browserslist:update": "npx browserslist@latest --update-db", | ||||
|     "fonts:update": "pnpm run fonts:download && pnpm run fonts:subset", | ||||
| @ -102,6 +103,7 @@ | ||||
|     "rollup": "3.9.1", | ||||
|     "rollup-plugin-visualizer": "5.9.0", | ||||
|     "sass": "1.57.1", | ||||
|     "start-server-and-test": "1.15.2", | ||||
|     "typescript": "4.9.4", | ||||
|     "vite": "4.0.3", | ||||
|     "vite-plugin-pwa": "0.14.1", | ||||
|  | ||||
							
								
								
									
										169
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										169
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							| @ -72,6 +72,7 @@ specifiers: | ||||
|   sass: 1.57.1 | ||||
|   snake-case: 3.0.4 | ||||
|   sortablejs: 1.15.0 | ||||
|   start-server-and-test: 1.15.2 | ||||
|   typescript: 4.9.4 | ||||
|   ufo: 1.0.1 | ||||
|   vite: 4.0.3 | ||||
| @ -171,6 +172,7 @@ devDependencies: | ||||
|   rollup: 3.9.1 | ||||
|   rollup-plugin-visualizer: 5.9.0_rollup@3.9.1 | ||||
|   sass: 1.57.1 | ||||
|   start-server-and-test: 1.15.2 | ||||
|   typescript: 4.9.4 | ||||
|   vite: 4.0.3_4ljv3kzetn75ixk7nciffo2yk4 | ||||
|   vite-plugin-pwa: 0.14.1_d6hwg7klbxt3x5xmvc2y355a7m | ||||
| @ -2159,7 +2161,7 @@ packages: | ||||
|       '@netlify/edge-bundler': 8.0.0 | ||||
|       '@netlify/functions-utils': 5.1.1_supports-color@9.2.1 | ||||
|       '@netlify/git-utils': 5.1.0 | ||||
|       '@netlify/plugins-list': 6.59.0 | ||||
|       '@netlify/plugins-list': 6.61.0 | ||||
|       '@netlify/run-utils': 5.1.0 | ||||
|       '@netlify/zip-it-and-ship-it': 8.2.0_supports-color@9.2.1 | ||||
|       '@sindresorhus/slugify': 2.1.0 | ||||
| @ -2665,8 +2667,8 @@ packages: | ||||
|     resolution: {integrity: sha512-1n9VvO/9qM7cRB5f7NgSNqeUrovM7j9WVAY7ZQ4LtQuXSquFmO9Fku7WrV3zAUC6v2Y62fxGyJ0fRllYz5uXLw==} | ||||
|     dev: true | ||||
|  | ||||
|   /@netlify/plugins-list/6.59.0: | ||||
|     resolution: {integrity: sha512-QLS3j9jf/5Jmu9x6OY+qp8i1mSCftBgq9SmE797mHP/TRD6+00C93pIdZN9KZJRUdyy8gts9K3XSXiS23LJJWA==} | ||||
|   /@netlify/plugins-list/6.61.0: | ||||
|     resolution: {integrity: sha512-76pkuMxDdRQcAKu5WXBl24fFCzjV8rQyBS2xh/xphAntPn57uLBtQYasncTzsgGjckWwDPjwoIkmxOzi3OeqFQ==} | ||||
|     engines: {node: ^14.14.0 || >=16.0.0} | ||||
|     dev: true | ||||
|  | ||||
| @ -2701,7 +2703,7 @@ packages: | ||||
|       junk: 4.0.0 | ||||
|       locate-path: 7.1.0 | ||||
|       merge-options: 3.0.4 | ||||
|       minimatch: 5.1.1 | ||||
|       minimatch: 5.1.2 | ||||
|       normalize-path: 3.0.0 | ||||
|       p-map: 5.5.0 | ||||
|       path-exists: 5.0.0 | ||||
| @ -2742,7 +2744,7 @@ packages: | ||||
|       junk: 4.0.0 | ||||
|       locate-path: 7.1.0 | ||||
|       merge-options: 3.0.4 | ||||
|       minimatch: 5.1.1 | ||||
|       minimatch: 5.1.2 | ||||
|       normalize-path: 3.0.0 | ||||
|       p-map: 5.5.0 | ||||
|       path-exists: 5.0.0 | ||||
| @ -3677,7 +3679,7 @@ packages: | ||||
|       '@vue/compiler-sfc': 3.2.45 | ||||
|       '@vue/reactivity': 3.2.45 | ||||
|       '@vue/shared': 3.2.45 | ||||
|       minimatch: 5.1.1 | ||||
|       minimatch: 5.1.2 | ||||
|       vue-template-compiler: 2.7.14 | ||||
|     dev: true | ||||
|  | ||||
| @ -4131,6 +4133,10 @@ packages: | ||||
|     resolution: {integrity: sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==} | ||||
|     dev: true | ||||
|  | ||||
|   /arg/5.0.2: | ||||
|     resolution: {integrity: sha512-PYjyFOLKQ9y57JvQ6QLo8dAgNqswh8M1RMJYdQduT6xbWSgK36P/Z/v+p888pM69jMMfS8Xd8F6I1kQ/I9HUGg==} | ||||
|     dev: true | ||||
|  | ||||
|   /argparse/2.0.1: | ||||
|     resolution: {integrity: sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==} | ||||
|  | ||||
| @ -4186,7 +4192,7 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /ascii-table/0.0.9: | ||||
|     resolution: {integrity: sha512-xpkr6sCDIYTPqzvjG8M3ncw1YOTaloWZOyrUmicoEifBEKzQzt+ooUpRpQ/AbOoJfO/p2ZKiyp79qHThzJDulQ==} | ||||
|     resolution: {integrity: sha1-BqZgTWpV1L9BqaR9mHLXp42jHnM=} | ||||
|     dev: true | ||||
|  | ||||
|   /asn1/0.2.6: | ||||
| @ -4273,6 +4279,14 @@ packages: | ||||
|     resolution: {integrity: sha512-xh1Rl34h6Fi1DC2WWKfxUTVqRsNnr6LsKz2+hfwDxQJWmrx8+c7ylaqBMcHfl1U1r2dsifOvKX3LQuLNZ+XSvA==} | ||||
|     dev: true | ||||
|  | ||||
|   /axios/0.25.0_debug@4.3.4: | ||||
|     resolution: {integrity: sha512-cD8FOb0tRH3uuEe6+evtAbgJtfxr7ly3fQjYcMcuPlgkwVS9xboaVIpcDV+cYQe+yGykgwZCs1pzjntcGa6l5g==} | ||||
|     dependencies: | ||||
|       follow-redirects: 1.15.1_debug@4.3.4 | ||||
|     transitivePeerDependencies: | ||||
|       - debug | ||||
|     dev: true | ||||
|  | ||||
|   /axios/0.27.2: | ||||
|     resolution: {integrity: sha512-t+yRIyySRTp/wua5xEr+z1q60QmLq8ABsS5O9Me1AsE5dfKqgnCFzwiCZZ/cGNd1lq4/7akDWMxdhVlucjmnOQ==} | ||||
|     dependencies: | ||||
| @ -4571,7 +4585,7 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /buffer-equal-constant-time/1.0.1: | ||||
|     resolution: {integrity: sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==} | ||||
|     resolution: {integrity: sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=} | ||||
|     dev: true | ||||
|  | ||||
|   /buffer-fill/1.0.0: | ||||
| @ -5138,7 +5152,7 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /concat-map/0.0.1: | ||||
|     resolution: {integrity: sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==} | ||||
|     resolution: {integrity: sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=} | ||||
|     dev: true | ||||
|  | ||||
|   /concordance/5.0.4: | ||||
| @ -5208,7 +5222,7 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /cookie-signature/1.0.6: | ||||
|     resolution: {integrity: sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==} | ||||
|     resolution: {integrity: sha1-4wOogrNCzD7oylE6eZmXNNqzriw=} | ||||
|     dev: true | ||||
|  | ||||
|   /cookie/0.5.0: | ||||
| @ -5973,7 +5987,7 @@ packages: | ||||
|   /dom-serializer/1.3.2: | ||||
|     resolution: {integrity: sha512-5c54Bk5Dw4qAxNOI1pFEizPSjVsx5+bpJKmL2kPn8JhBUq2q09tTCa3mjijun2NfK78NMouDYNMBkOrPZiS+ig==} | ||||
|     dependencies: | ||||
|       domelementtype: 2.3.0 | ||||
|       domelementtype: 2.2.0 | ||||
|       domhandler: 4.3.0 | ||||
|       entities: 2.2.0 | ||||
|     dev: true | ||||
| @ -5986,6 +6000,10 @@ packages: | ||||
|       entities: 4.4.0 | ||||
|     dev: true | ||||
|  | ||||
|   /domelementtype/2.2.0: | ||||
|     resolution: {integrity: sha512-DtBMo82pv1dFtUmHyr48beiuq792Sxohr+8Hm9zoxklYPfa6n0Z3Byjj2IV7bmr2IyqClnqEQhfgHJJ5QF0R5A==} | ||||
|     dev: true | ||||
|  | ||||
|   /domelementtype/2.3.0: | ||||
|     resolution: {integrity: sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==} | ||||
|     dev: true | ||||
| @ -5994,7 +6012,7 @@ packages: | ||||
|     resolution: {integrity: sha512-fC0aXNQXqKSFTr2wDNZDhsEYjCiYsDWl3D01kwt25hm1YIPyDGHvvi3rw+PLqHAl/m71MaiF7d5zvBr0p5UB2g==} | ||||
|     engines: {node: '>= 4'} | ||||
|     dependencies: | ||||
|       domelementtype: 2.3.0 | ||||
|       domelementtype: 2.2.0 | ||||
|     dev: true | ||||
|  | ||||
|   /domhandler/5.0.3: | ||||
| @ -6012,7 +6030,7 @@ packages: | ||||
|     resolution: {integrity: sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A==} | ||||
|     dependencies: | ||||
|       dom-serializer: 1.3.2 | ||||
|       domelementtype: 2.3.0 | ||||
|       domelementtype: 2.2.0 | ||||
|       domhandler: 4.3.0 | ||||
|     dev: true | ||||
|  | ||||
| @ -6079,6 +6097,10 @@ packages: | ||||
|       pify: 4.0.1 | ||||
|     dev: true | ||||
|  | ||||
|   /duplexer/0.1.2: | ||||
|     resolution: {integrity: sha512-jtD6YG370ZCIi/9GTaJKQxWTZD045+4R4hTk/x1UyoqadyJ9x9CgSi1RlVDQF8U2sxLLSnFkCaMihqljHIWgMg==} | ||||
|     dev: true | ||||
|  | ||||
|   /duplexer3/0.1.4: | ||||
|     resolution: {integrity: sha512-CEj8FwwNA4cVH2uFCoHUrmojhYh1vmCdOaneKJXwkeY1i9jnlslVo9dx+hQ5Hl9GnH/Bwy/IjxAyOePyPKYnzA==} | ||||
|     dev: true | ||||
| @ -6115,7 +6137,7 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /ee-first/1.1.1: | ||||
|     resolution: {integrity: sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==} | ||||
|     resolution: {integrity: sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=} | ||||
|     dev: true | ||||
|  | ||||
|   /ejs/3.1.6: | ||||
| @ -6505,6 +6527,18 @@ packages: | ||||
|     engines: {node: '>= 0.6'} | ||||
|     dev: true | ||||
|  | ||||
|   /event-stream/3.3.4: | ||||
|     resolution: {integrity: sha1-SrTJoPWlTbkzi0w02Gv86PSzVXE=} | ||||
|     dependencies: | ||||
|       duplexer: 0.1.2 | ||||
|       from: 0.1.7 | ||||
|       map-stream: 0.1.0 | ||||
|       pause-stream: 0.0.11 | ||||
|       split: 0.3.3 | ||||
|       stream-combiner: 0.0.4 | ||||
|       through: 2.3.8 | ||||
|     dev: true | ||||
|  | ||||
|   /eventemitter2/6.4.7: | ||||
|     resolution: {integrity: sha512-tYUSVOGeQPKt/eC1ABfhHy5Xd96N3oIijJvN3O9+TsC28T5V9yX9oEfEK5faP0EFSNVOG97qtAS68GBrQB2hDg==} | ||||
|     dev: true | ||||
| @ -6872,7 +6906,7 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /file-size/0.0.5: | ||||
|     resolution: {integrity: sha512-ZW056dw8Ta1RWHVOQue3LMZe+mSOnHkcM7AN9is8JoHSIHRiLD5szwPAHM3fM7P5SGJ1bkAmCv3PvUTGoluDqA==} | ||||
|     resolution: {integrity: sha1-BX1Dw6Ptc12j+Q1gUqs4Dx5tXjs=} | ||||
|     dev: true | ||||
|  | ||||
|   /file-type/11.1.0: | ||||
| @ -7126,10 +7160,14 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /fresh/0.5.2: | ||||
|     resolution: {integrity: sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==} | ||||
|     resolution: {integrity: sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=} | ||||
|     engines: {node: '>= 0.6'} | ||||
|     dev: true | ||||
|  | ||||
|   /from/0.1.7: | ||||
|     resolution: {integrity: sha512-twe20eF1OxVxp/ML/kq2p1uc6KvFK/+vs8WjEbeKmV2He22MKm7YF2ANIt+EOqhJ5L3K/SuuPhk0hWQDjOM23g==} | ||||
|     dev: true | ||||
|  | ||||
|   /from2-array/0.0.4: | ||||
|     resolution: {integrity: sha512-0G0cAp7sYLobH7ALsr835x98PU/YeVF7wlwxdWbCUaea7wsa7lJfKZUAo6p2YZGZ8F94luCuqHZS3JtFER6uPg==} | ||||
|     dependencies: | ||||
| @ -7380,7 +7418,7 @@ packages: | ||||
|       fs.realpath: 1.0.0 | ||||
|       inflight: 1.0.6 | ||||
|       inherits: 2.0.4 | ||||
|       minimatch: 5.1.1 | ||||
|       minimatch: 5.1.2 | ||||
|       once: 1.4.0 | ||||
|     dev: true | ||||
|  | ||||
| @ -8526,6 +8564,16 @@ packages: | ||||
|       supports-color: 7.2.0 | ||||
|     dev: true | ||||
|  | ||||
|   /joi/17.6.0: | ||||
|     resolution: {integrity: sha512-OX5dG6DTbcr/kbMFj0KGYxuew69HPcAE3K/sZpEV2nP6e/j/C0HV+HNiBPCASxdx5T7DMoa0s8UeHWMnb6n2zw==} | ||||
|     dependencies: | ||||
|       '@hapi/hoek': 9.2.1 | ||||
|       '@hapi/topo': 5.1.0 | ||||
|       '@sideway/address': 4.1.3 | ||||
|       '@sideway/formula': 3.0.0 | ||||
|       '@sideway/pinpoint': 2.0.0 | ||||
|     dev: true | ||||
|  | ||||
|   /joi/17.7.0: | ||||
|     resolution: {integrity: sha512-1/ugc8djfn93rTE3WRKdCzGGt/EtiYKxITMO4Wiv6q5JL1gl9ePt4kBsl1S499nbosspfctIQTpYIhSmHA3WAg==} | ||||
|     dependencies: | ||||
| @ -8571,7 +8619,7 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /json-buffer/3.0.0: | ||||
|     resolution: {integrity: sha512-CuUqjv0FUZIdXkHPI8MezCnFCdaTAacej1TZYulLoAg1h/PhwkdXFN4V/gzY4g+fMBCOV2xF+rp7t2XD2ns/NQ==} | ||||
|     resolution: {integrity: sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg=} | ||||
|     dev: true | ||||
|  | ||||
|   /json-buffer/3.0.1: | ||||
| @ -9160,6 +9208,10 @@ packages: | ||||
|     engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} | ||||
|     dev: true | ||||
|  | ||||
|   /map-stream/0.1.0: | ||||
|     resolution: {integrity: sha512-CkYQrPYZfWnu/DAmVCpTSX/xHpKZ80eKh2lAkyA6AJTef6bW+6JpbQZN5rofum7da+SyN1bi5ctTm+lTfcCW3g==} | ||||
|     dev: true | ||||
|  | ||||
|   /map-visit/1.0.0: | ||||
|     resolution: {integrity: sha512-4y7uGv8bd2WdM9vpQsiQNo41Ln1NvhvDRuVt0k2JZQ+ezN2uaQes7lZeZ+QQUHOLQAtDaBJ+7wCbi+ab/KFs+w==} | ||||
|     engines: {node: '>=0.10.0'} | ||||
| @ -9202,7 +9254,7 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /media-typer/0.3.0: | ||||
|     resolution: {integrity: sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==} | ||||
|     resolution: {integrity: sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=} | ||||
|     engines: {node: '>= 0.6'} | ||||
|     dev: true | ||||
|  | ||||
| @ -9228,7 +9280,7 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /merge-descriptors/1.0.1: | ||||
|     resolution: {integrity: sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==} | ||||
|     resolution: {integrity: sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=} | ||||
|     dev: true | ||||
|  | ||||
|   /merge-options/3.0.4: | ||||
| @ -9370,8 +9422,8 @@ packages: | ||||
|       brace-expansion: 1.1.11 | ||||
|     dev: true | ||||
|  | ||||
|   /minimatch/5.1.1: | ||||
|     resolution: {integrity: sha512-362NP+zlprccbEt/SkxKfRMHnNY85V74mVnpUpNyr3F35covl09Kec7/sEFLt3RA4oXmewtoaanoIf67SE5Y5g==} | ||||
|   /minimatch/5.1.2: | ||||
|     resolution: {integrity: sha512-bNH9mmM9qsJ2X4r2Nat1B//1dJVcn3+iBLa3IgqJ7EbGaDNepL9QSHOxN4ng33s52VMMhhIfgCYDk3C4ZmlDAg==} | ||||
|     engines: {node: '>=10'} | ||||
|     dependencies: | ||||
|       brace-expansion: 2.0.1 | ||||
| @ -9482,7 +9534,7 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /mute-stream/0.0.7: | ||||
|     resolution: {integrity: sha512-r65nCZhrbXXb6dXOACihYApHw2Q6pV0M3V0PSxd74N0+D8nzAdEAITq2oAjA1jVnKI+tGvEBUpqiMh0+rW6zDQ==} | ||||
|     resolution: {integrity: sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=} | ||||
|     dev: true | ||||
|  | ||||
|   /mute-stream/0.0.8: | ||||
| @ -10392,7 +10444,7 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /path-to-regexp/0.1.7: | ||||
|     resolution: {integrity: sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==} | ||||
|     resolution: {integrity: sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=} | ||||
|     dev: true | ||||
|  | ||||
|   /path-type/3.0.0: | ||||
| @ -10423,6 +10475,12 @@ packages: | ||||
|     resolution: {integrity: sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==} | ||||
|     dev: true | ||||
|  | ||||
|   /pause-stream/0.0.11: | ||||
|     resolution: {integrity: sha1-/lo0sMvOErWqaitAPuLnO2AvFEU=} | ||||
|     dependencies: | ||||
|       through: 2.3.8 | ||||
|     dev: true | ||||
|  | ||||
|   /pend/1.2.0: | ||||
|     resolution: {integrity: sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg==} | ||||
|     dev: true | ||||
| @ -11002,6 +11060,14 @@ packages: | ||||
|     engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} | ||||
|     dev: true | ||||
|  | ||||
|   /ps-tree/1.2.0: | ||||
|     resolution: {integrity: sha512-0VnamPPYHl4uaU/nSFeZZpR21QAWRz+sRv4iW9+v/GS/J5U5iZB5BNN6J0RMoOvdx2gWM2+ZFMIm58q24e4UYA==} | ||||
|     engines: {node: '>= 0.10'} | ||||
|     hasBin: true | ||||
|     dependencies: | ||||
|       event-stream: 3.3.4 | ||||
|     dev: true | ||||
|  | ||||
|   /psl/1.8.0: | ||||
|     resolution: {integrity: sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ==} | ||||
|     dev: true | ||||
| @ -11065,7 +11131,7 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /querystring/0.2.0: | ||||
|     resolution: {integrity: sha512-X/xY82scca2tau62i9mDyU9K+I+djTMUsvwf7xnUX5GLvVzgJybOJf4Y6o9Zx3oJK/LSXg5tTZBjwzqVPaPO2g==} | ||||
|     resolution: {integrity: sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=} | ||||
|     engines: {node: '>=0.4.x'} | ||||
|     deprecated: The querystring API is considered Legacy. new code should use the URLSearchParams API instead. | ||||
|     dev: true | ||||
| @ -11533,6 +11599,12 @@ packages: | ||||
|       tslib: 1.14.1 | ||||
|     dev: true | ||||
|  | ||||
|   /rxjs/7.5.4: | ||||
|     resolution: {integrity: sha512-h5M3Hk78r6wAheJF0a5YahB1yRQKCsZ4MsGdZ5O9ETbVtjPcScGfrMmoOq7EBsCRzd4BDkvDJ7ogP8Sz5tTFiQ==} | ||||
|     dependencies: | ||||
|       tslib: 2.3.1 | ||||
|     dev: true | ||||
|  | ||||
|   /rxjs/7.8.0: | ||||
|     resolution: {integrity: sha512-F2+gxDshqmIub1KdvZkaEfGDwLNpPvk9Fs6LD/MyQxNgMds/WH9OdDDXOmxUZpME+iSK3rQCctkL0DYyytUqMg==} | ||||
|     dependencies: | ||||
| @ -11917,6 +11989,12 @@ packages: | ||||
|       extend-shallow: 3.0.2 | ||||
|     dev: true | ||||
|  | ||||
|   /split/0.3.3: | ||||
|     resolution: {integrity: sha512-wD2AeVmxXRBoX44wAycgjVpMhvbwdI2aZjCkvfNcH1YqHQvJVa1duWc73OyVGJUc05fhFaTZeQ/PYsrmyH0JVA==} | ||||
|     dependencies: | ||||
|       through: 2.3.8 | ||||
|     dev: true | ||||
|  | ||||
|   /split2/1.1.1: | ||||
|     resolution: {integrity: sha512-cfurE2q8LamExY+lJ9Ex3ZfBwqAPduzOKVscPDXNCLLMvyaeD3DTz1yk7fVIs6Chco+12XeD0BB6HEoYzPYbXA==} | ||||
|     dependencies: | ||||
| @ -11953,6 +12031,23 @@ packages: | ||||
|     resolution: {integrity: sha512-h88QkzREN/hy8eRdyNhhsO7RSJ5oyTqxxmmn0dzBIMUclZsjpfmrsg81vp8mjjAs2vAZ72nyWxRUwSwmh0e4xg==} | ||||
|     dev: true | ||||
|  | ||||
|   /start-server-and-test/1.15.2: | ||||
|     resolution: {integrity: sha512-t5xJX04Hg7hqxiKHMJBz/n4zIMsE6G7hpAcerFAH+4Vh9le/LeyFcJERJM7WLiPygWF9TOg33oroJF1XOzJtYQ==} | ||||
|     engines: {node: '>=6'} | ||||
|     hasBin: true | ||||
|     dependencies: | ||||
|       arg: 5.0.2 | ||||
|       bluebird: 3.7.2 | ||||
|       check-more-types: 2.24.0 | ||||
|       debug: 4.3.4 | ||||
|       execa: 5.1.1 | ||||
|       lazy-ass: 1.6.0 | ||||
|       ps-tree: 1.2.0 | ||||
|       wait-on: 6.0.1_debug@4.3.4 | ||||
|     transitivePeerDependencies: | ||||
|       - supports-color | ||||
|     dev: true | ||||
|  | ||||
|   /static-extend/0.1.2: | ||||
|     resolution: {integrity: sha512-72E9+uLc27Mt718pMHt9VMNiAL4LMsmDbBva8mxWUCkT07fSzEGMYUCk0XWY6lp0j6RBAG4cJ3mWuZv2OE3s0g==} | ||||
|     engines: {node: '>=0.10.0'} | ||||
| @ -11988,6 +12083,12 @@ packages: | ||||
|     engines: {node: '>= 0.8'} | ||||
|     dev: true | ||||
|  | ||||
|   /stream-combiner/0.0.4: | ||||
|     resolution: {integrity: sha512-rT00SPnTVyRsaSz5zgSPma/aHSOic5U1prhYdRy5HS2kTZviFpmDgzilbtsJsxiroqACmayynDN/9VzIbX5DOw==} | ||||
|     dependencies: | ||||
|       duplexer: 0.1.2 | ||||
|     dev: true | ||||
|  | ||||
|   /strict-uri-encode/1.1.0: | ||||
|     resolution: {integrity: sha512-R3f198pcvnB+5IpnBlRkphuE9n46WyVl8I39W/ZUTZLz4nqSP/oLYUrcnJrw462Ds8he4YKMov2efsTIw1BDGQ==} | ||||
|     engines: {node: '>=0.10.0'} | ||||
| @ -12919,7 +13020,7 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /utils-merge/1.0.1: | ||||
|     resolution: {integrity: sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==} | ||||
|     resolution: {integrity: sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=} | ||||
|     engines: {node: '>= 0.4.0'} | ||||
|     dev: true | ||||
|  | ||||
| @ -12957,7 +13058,7 @@ packages: | ||||
|     dev: true | ||||
|  | ||||
|   /verror/1.10.0: | ||||
|     resolution: {integrity: sha512-ZZKSmDAEFOijERBLkmYfJ+vmk3w+7hOLYDNkRCuRuMJGEmqYNCNLyBBFwWKVMhfwaEF3WOd0Zlw86U/WC/+nYw==} | ||||
|     resolution: {integrity: sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=} | ||||
|     engines: {'0': node >=0.6.0} | ||||
|     dependencies: | ||||
|       assert-plus: 1.0.0 | ||||
| @ -13207,6 +13308,20 @@ packages: | ||||
|       '@vue/server-renderer': 3.2.45_vue@3.2.45 | ||||
|       '@vue/shared': 3.2.45 | ||||
|  | ||||
|   /wait-on/6.0.1_debug@4.3.4: | ||||
|     resolution: {integrity: sha512-zht+KASY3usTY5u2LgaNqn/Cd8MukxLGjdcZxT2ns5QzDmTFc4XoWBgC+C/na+sMRZTuVygQoMYwdcVjHnYIVw==} | ||||
|     engines: {node: '>=10.0.0'} | ||||
|     hasBin: true | ||||
|     dependencies: | ||||
|       axios: 0.25.0_debug@4.3.4 | ||||
|       joi: 17.6.0 | ||||
|       lodash: 4.17.21 | ||||
|       minimist: 1.2.7 | ||||
|       rxjs: 7.5.4 | ||||
|     transitivePeerDependencies: | ||||
|       - debug | ||||
|     dev: true | ||||
|  | ||||
|   /wait-on/7.0.1: | ||||
|     resolution: {integrity: sha512-9AnJE9qTjRQOlTZIldAaf/da2eW0eSRSgcqq85mXQja/DW3MriHxkpODDSUEg+Gri/rKEcXUZHe+cevvYItaog==} | ||||
|     engines: {node: '>=12.0.0'} | ||||
|  | ||||
| @ -10,8 +10,6 @@ | ||||
|     "importHelpers": true, | ||||
|     "sourceMap": true, | ||||
|     "strictNullChecks": true, | ||||
|     // "allowJs": true, | ||||
|     // "allowSyntheticDefaultImports": true, | ||||
|      | ||||
|     "paths": { | ||||
|       "@/*": ["./src/*"] | ||||
|  | ||||
| @ -1,8 +1,8 @@ | ||||
| { | ||||
|   "extends": "@vue/tsconfig/tsconfig.node.json", | ||||
|   "include": ["vite.config.*"], | ||||
|   "include": ["vite.config.*", "vitest.config.*", "cypress.config.*"], | ||||
|   "compilerOptions": { | ||||
|     "composite": true, | ||||
|     "types": ["node", "vitest"] | ||||
|     "types": ["node"] | ||||
|   } | ||||
| } | ||||
| @ -2,7 +2,7 @@ | ||||
|   "files": [], | ||||
|   "references": [ | ||||
|     { | ||||
|       "path": "./tsconfig.vite-config.json" | ||||
|       "path": "./tsconfig.config.json" | ||||
|     }, | ||||
|     { | ||||
|       "path": "./tsconfig.app.json" | ||||
|  | ||||
| @ -137,6 +137,7 @@ export default defineConfig({ | ||||
| 		extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue'], | ||||
| 	}, | ||||
| 	server: { | ||||
| 		host: '127.0.0.1', // see: https://github.com/vitejs/vite/pull/8543 | ||||
| 		port: 4173, | ||||
| 		strictPort: true, | ||||
| 	}, | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 konrad
					konrad