search

Home  >  Q&A  >  body text

Make sure the classname element Nuxt JS/Vue Jest checks exists on the page

I am new to the Jest test suite for Vue JS and integrating it into my Nuxt JS application. I've set up some basic tests to check if the component is a Vue instance and these tests pass successfully.

I'm now trying to find an element on my page and check if it exists, and what content might be in it.

This is my structure

pages/application/begin.vue

1

2

3

4

5

<template>

  <div>

    <LoanTerm />

  </div>

</template>

Components/Forms/Steps/Loan/LoanTerm.vue

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

<template>

  <article>

 

    <article class="tw-px-7 tw-pb-7">

      <StepHeader

        title="About your loan"

        subtitle="How long do you need the money for?" />

    </article>

    <hr class="tw-mt-7" />

    <article class="tw-p-7 tw-space-y-7">

 

      <section>

        <validation-provider

          vvid="loan.term"

          name="Loan term"

          rules="required"

          v-slot="{ errors, classes }"

        >

          <div class="tw-grid tw-grid-cols-2 tw-gap-4">

            <label

              v-for="(term, index) in datasets.terms.slice(0, 12)"

              v-if="index % 2 == 0"

              :key="index"

              :for="`term-${index}`"

              class="tw-flex-1 tw-relative tw-bg-gray-50 tw-rounded-xl tw-p-7 tw-border-b-4 tw-border-gray-200 tw-text-center tw-cursor-pointer"

              :class="$getClasses(classes, true, fields.loan.term === term.value)">

              <input type="radio" name="term" :id="`term-${index}`" :value="term.value" v-model="fields.loan.term" class="tw-absolute tw-top-4 tw-right-4 tw-h-4 tw-w-4 focus:tw-ring-green-500 tw-text-green-600 tw-border-gray-300 jest__datasets-terms" />

              <span class="tw-block">

                {{ term.label }}

              </span>

            </label>

          </div>

          <ValidationMessage :message="errors[0]" />

        </validation-provider>

      </section>

 

      <section class="tw-space-y-4">

        <modal

          title="Choose address"

          :is-open="termSelectionModalIsOpen">

          <template #action-close>

            <button @click="termSelectionModalIsOpen = false" type="button" class="tw-p-3 tw-rounded-full tw-text-gray-800 tw-border tw-border-gray-300 tw-font-extrabold focus:tw-outline-none focus:tw-ring-2 focus:tw-ring-offset-2 focus:tw-ring-offset-gray-200 focus:tw-ring-white">

              <svg xmlns="http://www.w3.org/2000/svg" class="tw-h-5 tw-w-5" fill="none" viewBox="0 0 24 24" stroke="currentColor">

                <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12" />

              </svg>

            </button>

          </template>

          <template #iterable-data>

            <section v-for="(term, index) in datasets.terms" :key="index">

              <button @click="chooseTerm(term)" type="button" class="tw-w-full tw-block md:hover:tw-bg-gray-50 tw-p-6 tw-text-left">

                <div class="tw-grid tw-grid-cols-3 tw-gap-6">

                  <div class="tw-col-span-2 tw-flex tw-items-center tw-text-gray-600">

                    {{ term.label }}

                  </div>

                  <div class="tw-text-right">

                    <button type="button" class="tw-p-3 tw-rounded-full tw-text-gray-800 tw-border tw-border-transparent tw-font-extrabold focus:tw-outline-none focus:tw-ring-2 focus:tw-ring-offset-2 focus:tw-ring-offset-gray-200 focus:tw-ring-white">

                      <svg xmlns="http://www.w3.org/2000/svg" class="tw-h-5 tw-w-5" fill="none" viewBox="0 0 24 24" stroke="currentColor">

                        <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 5l7 7-7 7" />

                      </svg>

                    </button>

                  </div>

                </div>

              </button>

              <hr />

            </section>

          </template>

        </modal>

        <button @click="termSelectionModalIsOpen = true" type="button" class="tw-py-5 tw-px-5 tw-rounded-xl tw-bg-gray-100 tw-flex tw-w-full tw-text-gray-600 tw-border tw-border-gray-200 tw-font-medium focus:tw-outline-none focus:tw-ring-2 focus:tw-ring-offset-2 focus:tw-ring-offset-gray-100 focus:tw-ring-white">

          <div class="tw-flex tw-mx-auto">

            <svg xmlns="http://www.w3.org/2000/svg" class="tw-h-5 tw-w-5 tw-mr-2" fill="none" viewBox="0 0 24 24" stroke="currentColor">

              <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 7V3m8 4V3m-9 8h10M5 21h14a2 2 0 002-2V7a2 2 0 00-2-2H5a2 2 0 00-2 2v12a2 2 0 002 2z" />

            </svg>

            Choose another term

          </div>

        </button>

        <div class="md:tw-shadow-lg">

          <button type="submit" class="tw-py-5 tw-px-5 tw-rounded-xl tw-bg-green-500 md:hover:tw-bg-green-600 tw-block tw-w-full tw-text-white tw-border tw-border-gray-300 tw-font-medium focus:tw-outline-none focus:tw-ring-2 focus:tw-ring-offset-2 focus:tw-ring-offset-gray-200 focus:tw-ring-white">

            Continue

          </button>

        </div>

      </section>

 

    </article>

 

  </article>

</template>

 

<script>

export default {

  props: {

    minTerm: {

      type: Number,

      default: 1

    },

    term: {

      type: Number,

      default: 7

    },

    maxTerm: {

      type: Number,

      default: 36

    },

    fields: {

      type: Object,

      default: () => ({ })

    }

  },

  data () {

    return {

      termSelectionModalIsOpen: false,

      datasets: {

        terms: []

      }

    }

  },

  created () {

    this.availableTerms()

  },

  methods: {

 

    /*

    ** Generate available terms

    */

    availableTerms () {

      for (let term = this.minTerm; term < this.maxTerm; term++) {

        this.datasets.terms.push({

          label: `${term} month${term == 1 ? '' : 's'}`,

          value: term

        })

      }

    },

 

    /*

    ** Choose term

    */

    chooseTerm (term = null) {

      this.fields.loan.term = term.value

      this.termSelectionModalIsOpen = false

      this.$store.commit('application/stepForwards')

    }

 

  }

}

</script>

The test I set up provides the following:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

import { mount } from '@vue/test-utils'

import LoanTerm from '@/components/Form/Steps/Loan/LoanTerm'

 

describe('LoanTerm', () => {

 

  test('is a Vue instance', () => {

    const wrapper = mount(LoanTerm)

    expect(wrapper.vm).toBeTruthy()

  })

 

  test('terms are available for selection', async () => {

    const wrapper = mount(LoanTerm)

    const terms = await wrapper.find('.jest__datasets-terms')

    expect(terms.exists()).toBe(true)

  })

 

})

The results I get when I run this test are my "Terms to choose from" "The test failed because it received error.

I also tried using findAll and it returns nothing

What did I miss?

P粉982054449P粉982054449278 days ago477

reply all(1)I'll reply

  • P粉495955986

    P粉4959559862024-04-01 13:13:57

    It looks like the contents of modal (including the "datasets-terms" button your test is looking for) are not rendered initially because termSelectionModalIsOpen is initialized to false and there is no setting to set it to true. The pattern might look similar to this:

    1

    2

    3

    4

    5

    6

    7

    8

    9

    // Modal.vue

    <template>

      <div v-if="isOpen">

        <slot name="iterable-data">

        <slot name="action-close">

      </slot></slot></div>

    </template>

     

    sssccc

    solution

    Mount LoanTerm using the data() property, which initializes termSelectionModalIsOpen to true so that the contents of the modal are rendered:

    1

    2

    3

    4

    5

    6

    7

    const wrapper = mount(LoanTerm, {

      data () {

        return {

          termSelectionModalIsOpen: true,

        }

      },

    })

    I noticed that the jest__datasets-terms class is missing from LoanTerm.vue, but I think it's just a copy-paste error.

    Demo

    reply
    0
  • Cancelreply