47 lines
1.1 KiB
TypeScript
47 lines
1.1 KiB
TypeScript
import { config, createLocalVue, mount } from "@vue/test-utils";
|
|
import { routes } from "@/router";
|
|
import App from "@/App.vue";
|
|
import VueRouter from "vue-router";
|
|
import Buefy from "buefy";
|
|
|
|
const localVue = createLocalVue();
|
|
config.mocks.$t = (key: string): string => key;
|
|
localVue.use(VueRouter);
|
|
localVue.use(Buefy);
|
|
|
|
describe("routing", () => {
|
|
test("Homepage", async () => {
|
|
const router = new VueRouter({ routes, mode: "history" });
|
|
const wrapper = mount(App, {
|
|
localVue,
|
|
router,
|
|
stubs: {
|
|
NavBar: true,
|
|
"mobilizon-footer": true,
|
|
},
|
|
});
|
|
|
|
expect(wrapper.html()).toContain('<div id="homepage">');
|
|
});
|
|
|
|
test("About", async () => {
|
|
const router = new VueRouter({ routes, mode: "history" });
|
|
const wrapper = mount(App, {
|
|
localVue,
|
|
router,
|
|
stubs: {
|
|
NavBar: true,
|
|
"mobilizon-footer": true,
|
|
},
|
|
});
|
|
|
|
router.push("/about");
|
|
await wrapper.vm.$nextTick();
|
|
await wrapper.vm.$nextTick();
|
|
expect(wrapper.vm.$route.path).toBe("/about/instance");
|
|
expect(wrapper.html()).toContain(
|
|
'<a href="/about/instance" aria-current="page"'
|
|
);
|
|
});
|
|
});
|