/** * @author Yosuke Ota */ 'use strict' const RuleTester = require('../../eslint-compat').RuleTester const rule = require('../../../lib/rules/no-use-v-if-with-v-for') const tester = new RuleTester({ languageOptions: { parser: require('vue-eslint-parser'), ecmaVersion: 2015 } }) tester.run('no-use-v-if-with-v-for', rule, { valid: [ { filename: 'test.vue', code: '' }, { filename: 'test.vue', code: '<template><div><div v-for="x in list" v-if="x"></div></div></template>', options: [{ allowUsingIterationVar: true }] }, { filename: 'test.vue', code: '<template><div><div v-for="x in list" v-if="x.foo"></div></div></template>', options: [{ allowUsingIterationVar: true }] }, { filename: 'test.vue', code: '<template><div><div v-for="(x,i) in list" v-if="i%2==0"></div></div></template>', options: [{ allowUsingIterationVar: true }] }, { filename: 'test.vue', code: '<template><div v-if="shown"><div v-for="(x,i) in list"></div></div></template>' }, { filename: 'test.vue', code: ` <template> <ul> <li v-for="user in activeUsers" :key="user.id" > {{ user.name }} <li> </ul> </template> ` }, { filename: 'test.vue', code: ` <template> <ul v-if="shouldShowUsers"> <li v-for="user in users" :key="user.id" > {{ user.name }} <li> </ul> </template> ` }, { filename: 'test.vue', code: '<template><div><div v-for="{x} in list" v-if="x"></div></div></template>', options: [{ allowUsingIterationVar: true }] }, { filename: 'test.vue', code: '<template><div><div v-for="{x,y,z} in list" v-if="y.foo"></div></div></template>', options: [{ allowUsingIterationVar: true }] }, { filename: 'test.vue', code: '<template><div><div v-for="({x,y,z},i) in list" v-if="i%2==0"></div></div></template>', options: [{ allowUsingIterationVar: true }] }, { filename: 'test.vue', code: '<template><div v-if="shown"><div v-for="({x,y,z},i) in list"></div></div></template>' }, { filename: 'test.vue', code: ` <template> <ul> <li v-for="{user} in activeUsers" :key="user.id" > {{ user.name }} <li> </ul> </template> ` }, { filename: 'test.vue', code: ` <template> <ul v-if="shouldShowUsers"> <li v-for="{user} in users" :key="user.id" > {{ user.name }} <li> </ul> </template> ` } ], invalid: [ { filename: 'test.vue', code: '<template><div><div v-for="x in list" v-if="shown"></div></div></template>', errors: [ { message: "This 'v-if' should be moved to the wrapper element.", line: 1 } ] }, { filename: 'test.vue', code: '<template><div><div v-for="x in list" v-if="list.length>0"></div></div></template>', errors: [ { message: "This 'v-if' should be moved to the wrapper element.", line: 1 } ] }, { filename: 'test.vue', code: '<template><div><div v-for="x in list" v-if="x.isActive"></div></div></template>', errors: [ { message: "The 'list' variable inside 'v-for' directive should be replaced with a computed property that returns filtered array instead. You should not mix 'v-for' with 'v-if'.", line: 1 } ] }, { filename: 'test.vue', code: ` <template> <ul> <li v-for="user in users" v-if="user.isActive" :key="user.id" > {{ user.name }} <li> </ul> </template> `, errors: [ { message: "The 'users' variable inside 'v-for' directive should be replaced with a computed property that returns filtered array instead. You should not mix 'v-for' with 'v-if'.", line: 6 } ] }, { filename: 'test.vue', code: ` <template> <ul> <li v-for="user in users" v-if="shouldShowUsers" :key="user.id" > {{ user.name }} <li> </ul> </template> `, errors: [ { message: "This 'v-if' should be moved to the wrapper element.", line: 6 } ] }, { filename: 'test.vue', code: '<template><div><div v-for="{x,y,z} in list" v-if="z.isActive"></div></div></template>', errors: [ { message: "The 'list' variable inside 'v-for' directive should be replaced with a computed property that returns filtered array instead. You should not mix 'v-for' with 'v-if'.", line: 1 } ] }, { filename: 'test.vue', code: ` <template> <ul> <li v-for="{foo, bar, user} in users" v-if="user.isActive" :key="user.id" > {{ user.name }} <li> </ul> </template> `, errors: [ { message: "The 'users' variable inside 'v-for' directive should be replaced with a computed property that returns filtered array instead. You should not mix 'v-for' with 'v-if'.", line: 6 } ] }, { filename: 'test.vue', code: ` <template> <ul> <li v-for="{foo, bar, user} in users" v-if="shouldShowUsers" :key="user.id" > {{ user.name }} <li> </ul> </template> `, errors: [ { message: "This 'v-if' should be moved to the wrapper element.", line: 6 } ] }, { filename: 'test.vue', code: '<template><div><div v-for="{x} in list()" v-if="x.isActive"></div></div></template>', errors: [ { message: "The 'list()' expression inside 'v-for' directive should be replaced with a computed property that returns filtered array instead. You should not mix 'v-for' with 'v-if'.", line: 1 } ] }, { filename: 'test.vue', code: '<template><div><div v-for="i in 5" v-if="i"></div></div></template>', errors: [ { message: "The '5' expression inside 'v-for' directive should be replaced with a computed property that returns filtered array instead. You should not mix 'v-for' with 'v-if'.", line: 1 } ] } ] })