First off, thanks for taking the time to contribute!
It is truly appreciated 😊
Please note we have a code of conduct. Follow it in all your interactions with the project.
- Before creating a new PR, please discuss the change via an issue
- If adding a new feature, write the corresponding tests
- Ensure that nothing is broken. You can use the demo page for that
- If applicable, update the documentation
- When solving a bug, please provide the steps to reproduce it. Codesandbox is your best friend for that
This project has 6 main folders:
build/
: Production Rollup build configurationexamples/
: Example projectsdemo/
: Demo page's codesrc/
: Vue Toastification's codetests/
: All of the tests
The main folders you'll probably be working with will be src/
, tests/
and demo/
.
These are all the files used by the plugin. Its folders and files are separated by type:
components/
: Plugin's Vue components. These are the Toast itself, close button, icon, progress bar, etcscss/
: All of the plugin's styling files are herets/
: Typescript files containing constants and other helper methods used across the componentstypes/
: Main typescript types and interfacesindex.ts
: Plugin entry point
Inside the tests/
folder you'll find some test utilities under utils/
and the unit tests under unit/
. All of the tests are separated by the files they are testing, under the same folder structure as in src/
.
We use Jest and Vue Test Utils for testing.
If you've never written tests for Vue, you may find this guide helpful. You may also check out our testing guide to learn how to write effective tests for this plugin.
This folder contains the code for the demo.
Developing a plugin is a little different than developing a website for there is no direct way to try it out. Because of that, the best way to test your changes when developing is by starting up the demo page locally.
- Node 10 or superior
- Yarn
Clone the repository and create a local branch:
git clone https://github.com/Maronato/vue-toastification.git
cd vue-toastification
git checkout -b my-branch
Install dependencies:
yarn install
To start the demo page, run
yarn dev
You can now play with it on localhost:8080
and see your changes being hot reloaded.
To run all tests:
yarn test
Or to watch for changes and only run tests related to changed files:
yarn test:watch
Remember that automated test coverage may not catch all of your feature's intricacies. Write thorough tests, not just tests that reach 100% codecov.
If your changes are related to anything but VtToastContainer
, they may be treated as regular Vue components or Typescript code during tests.
If you make changes to the UI, it'll probably break some snapshots. Make sure that all logic tests pass before overwriting snapshots.
If you plan on changing behavior related to VtToastContainer
or plugin initialization, you'll face issues because of the way the plugin injects the container onto the page.
To solve that, the loadPlugin
utility was created. You may import it from tests/utils/plugin
and use it to simulate a app.use(Toast)
call.
Each of the position wrappers (topLeft
, etc) also have a getToasts
method that returns a WrapperArray or its toasts.
Example usage:
import { ToastOptionsAndRequiredContent } from "src/types";
import { POSITION } from "src/ts/constants";
import loadPlugin from "tests/utils/plugin";
describe("test plugin", () => {
it("adds toast", async () => {
// Load plugin with default value for position
const options = { position: POSITION.BOTTOM_LEFT };
const {
toastInterface,
bottomLeft,
containerWrapper
} = loadPlugin(options);
// Get way to access list of toasts inside containerWrapper
const vm = (containerWrapper.vm as unknown) as {
toastArray: ToastOptionsAndRequiredContent[]
}
// Initially there should be no toasts
expect(vm.toastArray.length).toBe(0);
expect(bottomLeft.getToasts().length).toBe(0);
// Create a toast
const content = "I'm a toast";
toastInterface(content);
// Wait for render
await containerWrapper.vm.$nextTick();
// Toast should be created with correct content
expect(vm.toastArray.length).toBe(1);
expect(bottomLeft.getToasts().length).toBe(1);
expect(bottomLeft.getToasts().at(0).props().content).toBe(content);
});
});
By contributing, you agree that your contributions will be licensed under its MIT License.