Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Vue 3 upgrade #551

Open
wants to merge 22 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 21 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions frontend/.eslintrc.json
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
"prettier/prettier": "error",
"no-unused-vars": ["warn", { "argsIgnorePattern": "^_" }],
"no-multi-spaces": ["error", { "ignoreEOLComments": false }],
"import/no-extraneous-dependencies": ["error"],
"import/no-extraneous-dependencies": ["error", {"devDependencies": true}],
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is it a workaround? Not sure how it works exactly but it seems that true is made to ignore this rule [docs here].

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

From the documentation you linked, the value Defaults to true It means that there is no change in the logic. I don't remember adding that flag manually (although it is very possible that I forgot that I did it :) ) It is possible that it was added automatically when updating some package.

"eol-last": ["error", "always"],
"no-multiple-empty-lines": [
"error",
Expand All @@ -29,7 +29,7 @@
"jest/valid-expect": "error"
},
"parserOptions": {
"parser": "babel-eslint"
"parser": "@babel/eslint-parser"
},
"settings": {
"import/resolver": {
Expand Down
2 changes: 1 addition & 1 deletion frontend/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
FROM node:12
FROM node:19

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That's a huge jump :D

EXPOSE 8080

Expand Down
2 changes: 1 addition & 1 deletion frontend/babel.config.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
module.exports = {
presets: ['@vue/app']
presets: ['@vue/app'],
};
2 changes: 1 addition & 1 deletion frontend/jest.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,5 +4,5 @@ module.exports = {
testMatch: ['**/?(*.)+(spec).js'],
collectCoverage: true,
collectCoverageFrom: ['src/**/*', '!src/assets/**'],
transformIgnorePatterns: ['/node_modules/(?!(vue-scrollactive)/)']
transformIgnorePatterns: ['/node_modules/(?!(vue-scrollactive)/)'],
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is there a reason why we are ignoring this? I'm just curious - if the answer is more than 30sec of writing please ignore this :D

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't know. But because vue-scrollactive supported was dropped, I ended up rewriting scroll logic to vanilla js. In the newest PR I removed vue-scrollactive, to avoid confusion. Thank you for pointing that out.

};
155 changes: 118 additions & 37 deletions frontend/jest/utils.js
Original file line number Diff line number Diff line change
@@ -1,78 +1,159 @@
import { mount as nativeMount, createLocalVue } from '@vue/test-utils';
import Vuetify from 'vuetify';
import { mount as nativeMount } from '@vue/test-utils';
import { vi } from 'vitest';
import { createVuetify } from 'vuetify';
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do I understand correctly that we are nesting Vitest in Jest? If that's correct (just to get up to speed) why we are doing this? Again - if the answer demands too much let's skip it. I'm just fishing if there's something that should be added in the docs to explain how it works.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We are not nesting it, but unfortunately we are using both jest and vitest for now. At some point we need to reconfigure eslint to use vitest, and move all subpackages that are dependent on jest to something different (and most likely reconfigure that too).
Right now we run unittest with vitest, but eslint is configure with jest, as well as some subpackages.
Removing jest is something we should most likely do, but at lest for me it is not a simple task.

import { createStore } from 'vuex';
import Vuex from 'vuex';
import * as components from 'vuetify/components';
import * as directives from 'vuetify/directives';
import HacknightWrapper from '../src/components/Dashboard/Hacknight/HacknightWrapper.vue';
import HacknightsParticipants from '../src/components/Dashboard/HacknightsParticipants/HacknightsParticipants.vue';
import DashboardHeader from '../src/components/Dashboard/Header/DashboardHeader.vue';
import ParticipantsSearch from '../src/components/Dashboard/Participants/ParticipantsSearch/ParticipantsSearch.vue';
import ParticipantsList from '../src/components/Dashboard/Participants/ParticipantsList.vue';
import ParticipantsChart from '../src/components/Dashboard/ParticipantsChart/ParticipantsChart.vue';
import DashboardMain from '../src/components/Dashboard/DashboardMain.vue';
import AboutUs from '../src/components/HomePage/AboutUs/AboutUs.vue';
import ContactUs from '../src/components/HomePage/ContactUs/ContactUs.vue';
import HomePageHeader from '../src/components/HomePage/Header/HomePageHeader.vue';
import JoinUs from '../src/components/HomePage/JoinUs/JoinUs.vue';
import OurProjects from '../src/components/HomePage/OurProjects/OurProjects.vue';
import ModalContent from '../src/components/HomePage/OurProjects/ModalContent/ModalContent.vue';
import PageFooter from '../src/components/HomePage/PageFooter/PageFooter.vue';
import SocialMedia from '../src/components/HomePage/SocialMedia/SocialMedia.vue';
import HomePage from '../src/components/HomePage/HomePage.vue';
import LoginForm from '../src/components/Login/LoginForm.vue';

const storeObject = {
modules: {
hacknight: {
namespaced: true,
getters: {
getHacknights: jest.fn(() => []),
getHacknight: jest.fn(() => ({ participants: [] })),
getError: jest.fn()
getHacknights: vi.fn(() => []),
getHacknight: vi.fn(() => ({ participants: [] })),
getError: vi.fn(),
},
actions: { getHacknights: jest.fn() }
actions: { getHacknights: vi.fn() },
},
participant: {
namespaced: true,
getters: { getParticipants: jest.fn(() => []), getError: jest.fn() },
actions: { getParticipants: jest.fn() }
getters: { getParticipants: vi.fn(() => []), getError: vi.fn() },
actions: { getParticipants: vi.fn() },
},
auth: {
namespaced: true,
getters: { getError: jest.fn() }
getters: { getError: vi.fn() },
},
contact: {
namespaced: true,
getters: { successfullySent: jest.fn(), msgErrorRaised: jest.fn() }
}
}
getters: { successfullySent: vi.fn(), msgErrorRaised: vi.fn() },
},
},
};

// mount function from @vue/test-utils
// needs this enhancement to render vuetify components correctly
// source: https://vuetifyjs.com/en/getting-started/unit-testing/#mocking-vuetify

export const getMountWithVuetify = () => {
const localVue = createLocalVue();
const vuetify = new Vuetify();
const vuetify = createVuetify({
components,
directives,
});

return Component => {
return nativeMount(Component, { localVue, vuetify });
};
return nativeMount({
props: {},
global: {
components: {
HacknightWrapper,
HacknightsParticipants,
DashboardHeader,
ParticipantsSearch,
ParticipantsList,
ParticipantsChart,
DashboardMain,
AboutUs,
ContactUs,
HomePageHeader,
JoinUs,
OurProjects,
ModalContent,
PageFooter,
SocialMedia,
HomePage,
LoginForm,
},
plugins: [vuetify],
},
});
};

// mount function from @vue/test-utils
// needs this enhancement to render components using vuex correctly
// source: https://vue-test-utils.vuejs.org/guides/using-with-vuex.html

export const getMountWithVuex = () => {
const localVue = createLocalVue();
localVue.use(Vuex);
const store = createStore(storeObject);

return Component => {
const store = new Vuex.Store(storeObject);

return nativeMount(Component, { store, localVue, stubs: ['apexchart'] });
};
return nativeMount({
props: {},
global: {
components: {
HacknightWrapper,
HacknightsParticipants,
DashboardHeader,
ParticipantsSearch,
ParticipantsList,
ParticipantsChart,
DashboardMain,
AboutUs,
ContactUs,
HomePageHeader,
JoinUs,
OurProjects,
ModalContent,
PageFooter,
SocialMedia,
HomePage,
LoginForm,
},
plugins: [store],
},
});
};

// Use this function if you need to test a component
// that uses both Vuex and Vuetify

export const getMountWithProviders = () => {
const localVue = createLocalVue();
localVue.use(Vuex);
const vuetify = new Vuetify();

return Component => {
const store = new Vuex.Store(storeObject);
const store = createStore(storeObject);
const vuetify = createVuetify({
components,
directives,
});

return nativeMount(Component, {
store,
localVue,
vuetify,
stubs: ['apexchart']
});
};
return nativeMount({
props: {},
global: {
components: {
HacknightWrapper,
HacknightsParticipants,
DashboardHeader,
ParticipantsSearch,
ParticipantsList,
ParticipantsChart,
DashboardMain,
AboutUs,
ContactUs,
HomePageHeader,
JoinUs,
OurProjects,
ModalContent,
PageFooter,
SocialMedia,
HomePage,
LoginForm,
},
plugins: [store, vuetify],
},
});
};
70 changes: 39 additions & 31 deletions frontend/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,47 +5,55 @@
"scripts": {
"serve": "vue-cli-service serve",
"build": "vue-cli-service build",
"test": "vue-cli-service test:unit --collect-coverage",
"test": "vitest",
"test:watch": "vue-cli-service test:unit --watch",
"lint": "vue-cli-service lint --no-fix --max-warnings 0",
"lint:fix": "vue-cli-service lint "
},
"dependencies": {
"@mdi/font": "^4.5.95",
"apexcharts": "^3.27.1",
"axios": "^0.21.1",
"eslint-plugin-jest": "^24.5.0",
"@mdi/font": "^7.2.96",
"@vuelidate/core": "^2.0.2",
"@vuelidate/validators": "^2.0.2",
"apexcharts": "^3.37.3",
"axios": "^1.3.5",
"eslint-plugin-jest": "^27.2.1",
"lodash": "^4.17.21",
"vue": "^2.6.10",
"vue-apexcharts": "^1.6.1",
"vue-router": "^3.3.4",
"vue": "3.2.47",
"vue-gtag": "^2.0.1",
"vue-router": "^4.1.6",
"vue-scrollactive": "^0.9.3",
"vuelidate": "^0.7.4",
"vuetify": "^2.6.10",
"vuex": "^3.0.1",
"vue-gtag": "^1.16.1"
"vue3-apexcharts": "^1.4.1",
"vuetify": "3.3.17",
"vuex": "^4.1.0"
},
"devDependencies": {
"@vue/cli-plugin-babel": "^3.8.0",
"@vue/cli-plugin-eslint": "^3.8.0",
"@vue/cli-plugin-unit-jest": "~4.5.0",
"@vue/cli-service": "^3.8.0",
"@vue/test-utils": "^1.0.3",
"babel-eslint": "^10.0.1",
"eslint": "^5.8.0",
"eslint-config-prettier": "^4.3.0",
"eslint-plugin-import": "^2.17.3",
"eslint-plugin-prettier": "^3.1.0",
"eslint-plugin-vue": "^5.0.0-beta.4",
"husky": "^2.3.0",
"prettier": "^1.17.1",
"@babel/core": "^7.0.0",
"@babel/eslint-parser": "^7.21.3",
"@vitejs/plugin-vue": "^4.3.4",
"@vue/babel-preset-app": "^5.0.8",
"@vue/cli-plugin-babel": "^5.0.8",
"@vue/cli-plugin-eslint": "^5.0.8",
"@vue/cli-service": "^5.0.8",
"@vue/compiler-dom": "^3.2.47",
"@vue/compiler-sfc": "^3.2.47",
"@vue/server-renderer": "^3.2.47",
"@vue/test-utils": "^2.4.1",
"eslint": "^8.38.0",
"eslint-config-prettier": "^8.8.0",
"eslint-plugin-import": "^2.27.5",
"eslint-plugin-prettier": "^4.2.1",
"eslint-plugin-vue": "^9.10.0",
"husky": "^8.0.3",
"jsdom": "^22.1.0",
"prettier": "^2.8.7",
"sass": "~1.32.12",
"sass-loader": "^7.1.0",
"style-loader": "^0.23.1",
"vue-cli-plugin-vuetify": "^0.6.3",
"vue-template-compiler": "^2.6.10",
"vuetify-loader": "^1.3.0",
"webpack": "^4.39.3"
"sass-loader": "^13.2.2",
"style-loader": "^3.3.2",
"typescript": "^4.9.4",
"vite": "^4.4.9",
"vitest": "^0.34.6",
"webpack": "^5.75.0",
"webpack-plugin-vuetify": "^2.0.0"
},
"postcss": {
"plugins": {
Expand Down
4 changes: 2 additions & 2 deletions frontend/src/App.vue
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
<template>
<div>
<div id="app">
<v-app>
<router-view></router-view>
</v-app>
Expand All @@ -8,6 +8,6 @@

<script>
export default {
name: 'app'
name: 'app',
};
</script>
Loading
Loading