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

<template> line is shown as not covered if v-if used in component (4.6+, 5.0+) #368

Open
8 of 9 tasks
TheJaredWilcurt opened this issue Mar 14, 2024 · 8 comments
Open
8 of 9 tasks
Labels
bug Something isn't working has workaround

Comments

@TheJaredWilcurt
Copy link

TheJaredWilcurt commented Mar 14, 2024

Related plugins

Describe the bug

In 4.5.2 and below components with v-if would have 100% test coverage, now with 4.6.0 and above they will report the first line of the Vue component (<template>) as not being covered in tests.

template-coverage

I've made the min-repro as simple as possible, it boils down to this:

Example:

<template>
  <div v-if="true"></div>
</template>

<script>
export default {
  name: 'App'
};
</script>
import { shallowMount } from '@vue/test-utils';

import App from '../../src/App.vue';

describe('App.vue', () => {
  test('Shallow mount', async () => {
    const wrapper = shallowMount(App);

    expect(true)
      .toEqual(true);
  });
});

Reproduction

https://github.com/TheJaredWilcurt/vite-plugin-vue-min-repro

Steps to reproduce

  1. clone repo
  2. npm install
  3. npm t

System Info

Tested on Node 20 and 21, Ubuntu 22.04 LTS and also GHA.

Used Package Manager

npm

Logs

No response

Validations

@haoqunjiang haoqunjiang added bug Something isn't working and removed pending triage labels Mar 15, 2024
@TheJaredWilcurt
Copy link
Author

[email protected]@4.6.0

@TheJaredWilcurt TheJaredWilcurt changed the title <template> line is shown as not covered if v-if used in component (4.6+) <template> line is shown as not covered if v-if used in component (4.6+, 5.x+) May 19, 2024
@TheJaredWilcurt TheJaredWilcurt changed the title <template> line is shown as not covered if v-if used in component (4.6+, 5.x+) <template> line is shown as not covered if v-if used in component (4.6+, 5.0+) May 19, 2024
@TheJaredWilcurt
Copy link
Author

I made a new branch in the minrepro with today's date and the latest versions for all dependencies. Issue is still present:

@TheJaredWilcurt
Copy link
Author

Issue still present with latest dependencies:

@boboldehampsink
Copy link

Same here, still stuck on 4.5.2 all this time...

@dryton
Copy link

dryton commented Jan 6, 2025

Also unable to upgrade from 4.5.2 due to this coverage issue

@boboldehampsink
Copy link

Now also unable to use Vite 6 as 4.5.2 requires Vite 5

@edison1105
Copy link
Member

edison1105 commented Jan 17, 2025

It no longer works due to reuseAST, starting from version vue v3.4.3,

/**
* Versions before 3.4.3 have issues when the user has passed additional
* template parse options e.g. `isCustomElement`.
*/
function canReuseAST(version: string | undefined) {
if (version) {
const [_, minor, patch] = version.split('.').map(Number)
if (minor >= 4 && patch >= 3) {
return true
}
}
return false
}


here is a workaround

import { defineConfig } from 'vite';
import vue from '@vitejs/plugin-vue';
+import * as CompilerDOM from '@vue/compiler-dom'

export default defineConfig({
  plugins: [
    vue({
+      template:{
+        compiler: CompilerDOM
+      }
    })
  ],
  test: {
    environment: 'happy-dom',
    globals: true,
    coverage: {
      exclude: [
        '**/main.js'
      ]
    }
  }
});

@boboldehampsink
Copy link

boboldehampsink commented Jan 17, 2025

I have another workaround which patches the compiler version so it skips ast re-use:

vitest.config.js

import { defineConfig } from 'vitest/config';
import Vue from '@vitejs/plugin-vue';
import * as compiler from 'vue/compiler-sfc';

export default defineConfig({
  plugins: [
    Vue({
      compiler: { ...compiler, version: '3.4.2' },
    }),
  ],
});

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working has workaround
Projects
None yet
Development

No branches or pull requests

5 participants