Модуль Vue.js: тестирование - Как работать с миксином и передавать его реквизитам - PullRequest
0 голосов
/ 20 сентября 2018

Я пытаюсь проверить мой компонент AudioPlayer, использующий миксин (vue-howler)

<script>
import VueHowler from "vue-howler";

...

export default {
  mixins: [VueHowler],
  name: "audioPlayer",
  data() {
    return {
      percentage: 0
    };
  },
...
</script>

Мне нужно передать реквизиты в миксин, как я могу это сделать?

  sources ( an Array of audio files ), autoplay (Boolean ) , ...

my AudioPlayer.spec.js

import Vue from "vue";
import { shallowMount } from "@vue/test-utils";
import Vuetify from "vuetify";
import AudioPlayer from "@/components/Home/AudioPlayer.vue";
import VueHowler from "vue-howler";


describe("AudioPlayer.vue", () => {
  beforeEach(() => {
    Vue.use(Vuetify);
    const el = document.createElement("div");
    el.setAttribute("data-app", true);
    document.body.appendChild(el);
  });

  const sourceFiles = [require("@/assets/audio/ultimo_desejo.mp3")];

  it("should emit an event PLAY/PAUSE  from playPauseBtn", () => {
    // given
    const wrapper = shallowMount(AudioPlayer, {
      attachToDocument: true,
      mixins: [VueHowler]
    });
    wrapper.setData({ paused: true, playing: false });
    console.log(wrapper.html());
  });

Vue-Howler Mixin

import { Howl } from 'howler'
import clamp from 'math-clamp'
import values from 'object-values'
import assign from 'object-assign'

export default {
  props: {
    /**
     * An array of audio file urls
     */
    sources: {
      type: Array,
      required: true,
      validator(sources) {
        // Every source must be a non-empty string
        return sources.every(
          source => typeof source === 'string' && source.length > 0
        )
      }
    },
    /**
     * Whether to start the playback
     * when the component is mounted
     */
    autoplay: {
      type: Boolean,
      default: false
    },
    /**
     * Whether to start the playback again
     * automatically after it is done playing
     */
    loop: {
      type: Boolean,
      default: false
      ....

1 Ответ

0 голосов
/ 20 сентября 2018

РЕШЕНО ... нужно передать propseDta ДО миксинов в мелкой горе

  const sourceFiles = ['require("@/assets/audio/ultimo_desejo.mp3"']

  it("should emit an event PLAY/PAUSE  from playPauseBtn", () => {
    // given
    const wrapper = shallowMount(AudioPlayer, {
      // attachToDocument: true,
      propsData: {
        sources: sourceFiles,
        autoplay: false,
        loop: false
      },
      mixins: [VueHowler]
    });
    wrapper.setData({ paused: true, playing: false });
    console.log(wrapper.html());
  });
...