diff --git a/.github/ISSUE_TEMPLATE.md b/.github/ISSUE_TEMPLATE.md
index 036aa28..1f65133 100644
--- a/.github/ISSUE_TEMPLATE.md
+++ b/.github/ISSUE_TEMPLATE.md
@@ -13,11 +13,12 @@ learn how: http://kcd.im/pull-request
- `babel-plugin-macros` version:
- `node` version:
-- `npm` (or `yarn`) version:
+- `npm` version:
Relevant code or config
```javascript
+
```
What you did:
diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md
index 920dbc9..3af53f1 100644
--- a/.github/PULL_REQUEST_TEMPLATE.md
+++ b/.github/PULL_REQUEST_TEMPLATE.md
@@ -1,5 +1,5 @@
+
+**Checklist**:
+
+
+
+
+- [ ] Documentation
+- [ ] Tests
+- [ ] Ready to be merged
+
+
diff --git a/.github/workflows/validate.yml b/.github/workflows/validate.yml
new file mode 100644
index 0000000..abe36fb
--- /dev/null
+++ b/.github/workflows/validate.yml
@@ -0,0 +1,80 @@
+name: validate
+on:
+ push:
+ branches:
+ - '+([0-9])?(.{+([0-9]),x}).x'
+ - 'master'
+ - 'next'
+ - 'next-major'
+ - 'beta'
+ - 'alpha'
+ - '!all-contributors/**'
+ pull_request: {}
+jobs:
+ main:
+ # ignore all-contributors PRs
+ if: ${{ !contains(github.head_ref, 'all-contributors') }}
+ strategy:
+ matrix:
+ node: [10.13, 12, 14, 15]
+ runs-on: ubuntu-latest
+ steps:
+ - name: ⬇️ Checkout repo
+ uses: actions/checkout@v2
+
+ - name: ⎔ Setup node
+ uses: actions/setup-node@v1
+ with:
+ node-version: ${{ matrix.node }}
+
+ - name: 📥 Download deps
+ uses: bahmutov/npm-install@v1
+ with:
+ useLockFile: false
+
+ - name: ▶️ Run validate script
+ run: npm run validate
+
+ - name: ⬆️ Upload coverage report
+ uses: codecov/codecov-action@v1
+
+ release:
+ needs: main
+ runs-on: ubuntu-latest
+ if:
+ ${{ github.repository == 'kentcdodds/babel-plugin-macros' &&
+ contains('refs/heads/master,refs/heads/beta,refs/heads/next,refs/heads/alpha',
+ github.ref) && github.event_name == 'push' }}
+ steps:
+ - name: ⬇️ Checkout repo
+ uses: actions/checkout@v2
+
+ - name: ⎔ Setup node
+ uses: actions/setup-node@v1
+ with:
+ node-version: 14
+
+ - name: 📥 Download deps
+ uses: bahmutov/npm-install@v1
+ with:
+ useLockFile: false
+
+ - name: 🏗 Run build script
+ run: npm run build
+
+ - name: 🚀 Release
+ uses: cycjimmy/semantic-release-action@v2
+ with:
+ semantic_version: 17
+ branches: |
+ [
+ '+([0-9])?(.{+([0-9]),x}).x',
+ 'master',
+ 'next',
+ 'next-major',
+ {name: 'beta', prerelease: true},
+ {name: 'alpha', prerelease: true}
+ ]
+ env:
+ GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
+ NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
diff --git a/.npmrc b/.npmrc
index 1e23fdf..214c29d 100644
--- a/.npmrc
+++ b/.npmrc
@@ -1 +1 @@
-registry=http://registry.npmjs.org
+registry=https://registry.npmjs.org/
diff --git a/.travis.yml b/.travis.yml
deleted file mode 100644
index 52ffdf9..0000000
--- a/.travis.yml
+++ /dev/null
@@ -1,30 +0,0 @@
-language: node_js
-cache: npm
-notifications:
- email: false
-node_js:
- - 10.0.0
- - 12
- - node
-os:
- - linux
- - windows
-# Travis does not support secrets on Windows yet so we test only external PRs where the secrets are not exposed
-# https://travis-ci.community/t/current-known-issues-please-read-this-before-posting-a-new-topic/264
-if: os = linux OR (type = pull_request AND head_repo != repo)
-install: npm install
-script:
- - npm run validate
- - npx codecov@3
-branches:
- only:
- - master
- - beta
-
-jobs:
- include:
- - stage: release
- node_js: 12
- # Build release on linux
- os: linux
- script: kcd-scripts travis-release
diff --git a/CODE_OF_CONDUCT.md b/CODE_OF_CONDUCT.md
new file mode 100644
index 0000000..47681ae
--- /dev/null
+++ b/CODE_OF_CONDUCT.md
@@ -0,0 +1,128 @@
+# Contributor Covenant Code of Conduct
+
+## Our Pledge
+
+We as members, contributors, and leaders pledge to make participation in our
+community a harassment-free experience for everyone, regardless of age, body
+size, visible or invisible disability, ethnicity, sex characteristics, gender
+identity and expression, level of experience, education, socio-economic status,
+nationality, personal appearance, race, religion, or sexual identity and
+orientation.
+
+We pledge to act and interact in ways that contribute to an open, welcoming,
+diverse, inclusive, and healthy community.
+
+## Our Standards
+
+Examples of behavior that contributes to a positive environment for our
+community include:
+
+- Demonstrating empathy and kindness toward other people
+- Being respectful of differing opinions, viewpoints, and experiences
+- Giving and gracefully accepting constructive feedback
+- Accepting responsibility and apologizing to those affected by our mistakes,
+ and learning from the experience
+- Focusing on what is best not just for us as individuals, but for the overall
+ community
+
+Examples of unacceptable behavior include:
+
+- The use of sexualized language or imagery, and sexual attention or advances of
+ any kind
+- Trolling, insulting or derogatory comments, and personal or political attacks
+- Public or private harassment
+- Publishing others' private information, such as a physical or email address,
+ without their explicit permission
+- Other conduct which could reasonably be considered inappropriate in a
+ professional setting
+
+## Enforcement Responsibilities
+
+Community leaders are responsible for clarifying and enforcing our standards of
+acceptable behavior and will take appropriate and fair corrective action in
+response to any behavior that they deem inappropriate, threatening, offensive,
+or harmful.
+
+Community leaders have the right and responsibility to remove, edit, or reject
+comments, commits, code, wiki edits, issues, and other contributions that are
+not aligned to this Code of Conduct, and will communicate reasons for moderation
+decisions when appropriate.
+
+## Scope
+
+This Code of Conduct applies within all community spaces, and also applies when
+an individual is officially representing the community in public spaces.
+Examples of representing our community include using an official e-mail address,
+posting via an official social media account, or acting as an appointed
+representative at an online or offline event.
+
+## Enforcement
+
+Instances of abusive, harassing, or otherwise unacceptable behavior may be
+reported to the community leaders responsible for enforcement at
+me+coc@kentcdodds.com. All complaints will be reviewed and investigated promptly
+and fairly.
+
+All community leaders are obligated to respect the privacy and security of the
+reporter of any incident.
+
+## Enforcement Guidelines
+
+Community leaders will follow these Community Impact Guidelines in determining
+the consequences for any action they deem in violation of this Code of Conduct:
+
+### 1. Correction
+
+**Community Impact**: Use of inappropriate language or other behavior deemed
+unprofessional or unwelcome in the community.
+
+**Consequence**: A private, written warning from community leaders, providing
+clarity around the nature of the violation and an explanation of why the
+behavior was inappropriate. A public apology may be requested.
+
+### 2. Warning
+
+**Community Impact**: A violation through a single incident or series of
+actions.
+
+**Consequence**: A warning with consequences for continued behavior. No
+interaction with the people involved, including unsolicited interaction with
+those enforcing the Code of Conduct, for a specified period of time. This
+includes avoiding interactions in community spaces as well as external channels
+like social media. Violating these terms may lead to a temporary or permanent
+ban.
+
+### 3. Temporary Ban
+
+**Community Impact**: A serious violation of community standards, including
+sustained inappropriate behavior.
+
+**Consequence**: A temporary ban from any sort of interaction or public
+communication with the community for a specified period of time. No public or
+private interaction with the people involved, including unsolicited interaction
+with those enforcing the Code of Conduct, is allowed during this period.
+Violating these terms may lead to a permanent ban.
+
+### 4. Permanent Ban
+
+**Community Impact**: Demonstrating a pattern of violation of community
+standards, including sustained inappropriate behavior, harassment of an
+individual, or aggression toward or disparagement of classes of individuals.
+
+**Consequence**: A permanent ban from any sort of public interaction within the
+community.
+
+## Attribution
+
+This Code of Conduct is adapted from the [Contributor Covenant][homepage],
+version 2.0, available at
+https://www.contributor-covenant.org/version/2/0/code_of_conduct.html.
+
+Community Impact Guidelines were inspired by
+[Mozilla's code of conduct enforcement ladder](https://github.com/mozilla/diversity).
+
+[homepage]: https://www.contributor-covenant.org
+
+For answers to common questions about this code of conduct, see the FAQ at
+https://www.contributor-covenant.org/faq. Translations are available at
+https://www.contributor-covenant.org/translations.
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index 0932077..01ff02c 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -8,24 +8,23 @@ series [How to Contribute to an Open Source Project on GitHub][egghead]
## Project setup
1. Fork and clone the repo
-2. `$ npm install` to install dependencies
-3. `$ npm run validate` to validate you've got it working
-4. Create a branch for your PR
+2. Run `npm run setup -s` to install dependencies and run validation
+3. Create a branch for your PR with `git checkout -b pr/your-branch-name`
-> Tip: Keep your `master` branch pointing at the original repository and make
-> pull requests from branches on your fork. To do this, run:
+> Tip: Keep your `main` branch pointing at the original repository and make pull
+> requests from branches on your fork. To do this, run:
>
> ```
> git remote add upstream https://github.com/kentcdodds/babel-plugin-macros
> git fetch upstream
-> git branch --set-upstream-to=upstream/master master
+> git branch --set-upstream-to=upstream/main main
> ```
>
> This will add the original repository as a "remote" called "upstream," Then
-> fetch the git information from that remote, then set your local `master`
-> branch to use the upstream master branch whenever you run `git pull`. Then you
-> can make all of your pull request branches based on this `master` branch.
-> Whenever you want to update your version of `master`, do a regular `git pull`.
+> fetch the git information from that remote, then set your local `main` branch
+> to use the upstream main branch whenever you run `git pull`. Then you can make
+> all of your pull request branches based on this `main` branch. Whenever you
+> want to update your version of `main`, do a regular `git pull`.
## Committing and Pushing changes
@@ -42,5 +41,6 @@ requests! Thanks!
[egghead]: https://egghead.io/series/how-to-contribute-to-an-open-source-project-on-github
+[all-contributors]: https://github.com/all-contributors/all-contributors
[issues]: https://github.com/kentcdodds/babel-plugin-macros/issues
diff --git a/LICENSE b/LICENSE
index 4c43675..a077a44 100644
--- a/LICENSE
+++ b/LICENSE
@@ -1,5 +1,5 @@
The MIT License (MIT)
-Copyright (c) 2017 Kent C. Dodds
+Copyright (c) 2020 Kent C. Dodds
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
diff --git a/README.md b/README.md
index 7638e9d..031b718 100644
--- a/README.md
+++ b/README.md
@@ -12,10 +12,7 @@
[![version][version-badge]][package]
[![downloads][downloads-badge]][npmtrends]
[![MIT License][license-badge]][license]
-
-
-[![All Contributors](https://img.shields.io/badge/all_contributors-28-orange.svg?style=flat-square)](#contributors-)
-
+[![All Contributors][all-contributors-badge]](#contributors-)
[![PRs Welcome][prs-badge]][prs]
[![Code of Conduct][coc-badge]][coc]
@@ -133,10 +130,10 @@ you could use `babel-plugin-macros` for, like:
## Installation
This module is distributed via [npm][npm] which is bundled with [node][node] and
-should be installed as one of your project's `dependencies`:
+should be installed as one of your project's `devDependencies`:
```
-npm install babel-plugin-macros
+npm install --save-dev babel-plugin-macros
```
## Usage
@@ -232,7 +229,7 @@ When that code is run, the `scope` function does some pretty nifty things:
**Node:**
-
+
Instead, let's use the macro it's shipped with like this:
@@ -415,6 +412,7 @@ Thanks goes to these people ([emoji key][emojis]):
+
This project follows the [all-contributors][all-contributors] specification.
@@ -427,8 +425,8 @@ MIT
[npm]: https://www.npmjs.com
[node]: https://nodejs.org
-[build-badge]: https://img.shields.io/travis/kentcdodds/babel-plugin-macros.svg?style=flat-square
-[build]: https://travis-ci.com/kentcdodds/babel-plugin-macros
+[build-badge]: https://img.shields.io/github/workflow/status/kentcdodds/babel-plugin-macros/validate?logo=github&style=flat-square
+[build]: https://github.com/kentcdodds/babel-plugin-macros/actions?query=workflow%3Avalidate
[coverage-badge]: https://img.shields.io/codecov/c/github/kentcdodds/babel-plugin-macros.svg?style=flat-square
[coverage]: https://codecov.io/github/kentcdodds/babel-plugin-macros
[version-badge]: https://img.shields.io/npm/v/babel-plugin-macros.svg?style=flat-square
@@ -436,19 +434,15 @@ MIT
[downloads-badge]: https://img.shields.io/npm/dm/babel-plugin-macros.svg?style=flat-square
[npmtrends]: http://www.npmtrends.com/babel-plugin-macros
[license-badge]: https://img.shields.io/npm/l/babel-plugin-macros.svg?style=flat-square
-[license]: https://github.com/kentcdodds/babel-plugin-macros/blob/master/LICENSE
+[license]: https://github.com/kentcdodds/babel-plugin-macros/blob/main/LICENSE
[prs-badge]: https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square
[prs]: http://makeapullrequest.com
[coc-badge]: https://img.shields.io/badge/code%20of-conduct-ff69b4.svg?style=flat-square
-[coc]: https://github.com/kentcdodds/babel-plugin-macros/blob/master/other/CODE_OF_CONDUCT.md
+[coc]: https://github.com/kentcdodds/babel-plugin-macros/blob/main/CODE_OF_CONDUCT.md
[emojis]: https://github.com/all-contributors/all-contributors#emoji-key
[all-contributors]: https://github.com/all-contributors/all-contributors
+[all-contributors-badge]: https://img.shields.io/github/all-contributors/kentcdodds/babel-plugin-macros?color=orange&style=flat-square
[bugs]: https://github.com/kentcdodds/babel-plugin-macros/issues?utf8=%E2%9C%93&q=is%3Aissue+is%3Aopen+sort%3Acreated-desc+label%3Abug
[requests]: https://github.com/kentcdodds/babel-plugin-macros/issues?utf8=%E2%9C%93&q=is%3Aissue+is%3Aopen+sort%3Areactions-%2B1-desc+label%3Aenhancement
[good-first-issue]: https://github.com/kentcdodds/babel-plugin-macros/issues?utf8=%E2%9C%93&q=is%3Aissue+is%3Aopen+sort%3Areactions-%2B1-desc+label%3Aenhancement+label%3A%22good+first+issue%22
-
-
-[preval]: https://github.com/kentcdodds/babel-plugin-preval
-[cra]: https://github.com/facebookincubator/create-react-app
-[cra-issue]: https://github.com/facebookincubator/create-react-app/issues/2730
diff --git a/other/CODE_OF_CONDUCT.md b/other/CODE_OF_CONDUCT.md
deleted file mode 100644
index 070cb5f..0000000
--- a/other/CODE_OF_CONDUCT.md
+++ /dev/null
@@ -1,75 +0,0 @@
-# Contributor Covenant Code of Conduct
-
-## Our Pledge
-
-In the interest of fostering an open and welcoming environment, we as
-contributors and maintainers pledge to making participation in our project and
-our community a harassment-free experience for everyone, regardless of age, body
-size, disability, ethnicity, gender identity and expression, level of
-experience, nationality, personal appearance, race, religion, or sexual identity
-and orientation.
-
-## Our Standards
-
-Examples of behavior that contributes to creating a positive environment
-include:
-
-- Using welcoming and inclusive language
-- Being respectful of differing viewpoints and experiences
-- Gracefully accepting constructive criticism
-- Focusing on what is best for the community
-- Showing empathy towards other community members
-
-Examples of unacceptable behavior by participants include:
-
-- The use of sexualized language or imagery and unwelcome sexual attention or
- advances
-- Trolling, insulting/derogatory comments, and personal or political attacks
-- Public or private harassment
-- Publishing others' private information, such as a physical or electronic
- address, without explicit permission
-- Other conduct which could reasonably be considered inappropriate in a
- professional setting
-
-## Our Responsibilities
-
-Project maintainers are responsible for clarifying the standards of acceptable
-behavior and are expected to take appropriate and fair corrective action in
-response to any instances of unacceptable behavior.
-
-Project maintainers have the right and responsibility to remove, edit, or reject
-comments, commits, code, wiki edits, issues, and other contributions that are
-not aligned to this Code of Conduct, or to ban temporarily or permanently any
-contributor for other behaviors that they deem inappropriate, threatening,
-offensive, or harmful.
-
-## Scope
-
-This Code of Conduct applies both within project spaces and in public spaces
-when an individual is representing the project or its community. Examples of
-representing a project or community include using an official project e-mail
-address, posting via an official social media account, or acting as an appointed
-representative at an online or offline event. Representation of a project may be
-further defined and clarified by project maintainers.
-
-## Enforcement
-
-Instances of abusive, harassing, or otherwise unacceptable behavior may be
-reported by contacting the project team at kent+coc@doddsfamily.us. All
-complaints will be reviewed and investigated and will result in a response that
-is deemed necessary and appropriate to the circumstances. The project team is
-obligated to maintain confidentiality with regard to the reporter of an
-incident. Further details of specific enforcement policies may be posted
-separately.
-
-Project maintainers who do not follow or enforce the Code of Conduct in good
-faith may face temporary or permanent repercussions as determined by other
-members of the project's leadership.
-
-## Attribution
-
-This Code of Conduct is adapted from the [Contributor Covenant][homepage],
-version 1.4, available at [http://contributor-covenant.org/version/1/4][version]
-
-[homepage]: http://contributor-covenant.org
-[version]: http://contributor-covenant.org/version/1/4/
diff --git a/other/MAINTAINING.md b/other/MAINTAINING.md
index 703126d..da09ba7 100644
--- a/other/MAINTAINING.md
+++ b/other/MAINTAINING.md
@@ -32,9 +32,9 @@ any more of you than that.
As a maintainer, you're fine to make your branches on the main repo or on your
own fork. Either way is fine.
-When we receive a pull request, a travis build is kicked off automatically (see
-the `.travis.yml` for what runs in the travis build). We avoid merging anything
-that breaks the travis build.
+When we receive a pull request, a github action is kicked off automatically (see
+the `.github/workflows/validate.yml` for what runs in the action). We avoid
+merging anything that breaks the validate action.
Please review PRs and focus on the code rather than the individual. You never
know when this is someone's first ever PR and we want their experience to be as
@@ -48,8 +48,8 @@ to release. See the next section on Releases for more about that.
## Release
-Our releases are automatic. They happen whenever code lands into `master`. A
-travis build gets kicked off and if it's successful, a tool called
+Our releases are automatic. They happen whenever code lands into `main`. A
+github action gets kicked off and if it's successful, a tool called
[`semantic-release`](https://github.com/semantic-release/semantic-release) is
used to automatically publish a new release to npm as well as a changelog to
GitHub. It is only able to determine the version and whether a release is
diff --git a/other/USERS.md b/other/USERS.md
new file mode 100644
index 0000000..4bc1281
--- /dev/null
+++ b/other/USERS.md
@@ -0,0 +1,12 @@
+# Users
+
+If you or your company uses this project, add your name to this list! Eventually
+we may have a website to showcase these (wanna build it!?)
+
+> No users have been added yet!
+
+
diff --git a/other/manual-releases.md b/other/manual-releases.md
index 154fc8a..8b722db 100644
--- a/other/manual-releases.md
+++ b/other/manual-releases.md
@@ -41,4 +41,4 @@ change is to release a new patch version.
Reference: #
```
-The number of times we've had to do a manual release is: 1
+The number of times we've had to do a manual release is: 0
diff --git a/package.json b/package.json
index 8ddae63..e580cc7 100644
--- a/package.json
+++ b/package.json
@@ -26,20 +26,20 @@
"author": "Kent C. Dodds (https://kentcdodds.com)",
"license": "MIT",
"dependencies": {
- "@babel/runtime": "^7.9.2",
- "@babel/traverse": "^7.10.1",
- "cosmiconfig": "^6.0.0",
- "resolve": "^1.15.1"
+ "@babel/runtime": "^7.12.5",
+ "@babel/traverse": "^7.12.9",
+ "cosmiconfig": "^7.0.0",
+ "resolve": "^1.19.0"
},
"devDependencies": {
- "@babel/core": "^7.9.0",
- "@babel/parser": "^7.9.3",
- "@babel/types": "^7.9.0",
+ "@babel/core": "^7.12.9",
+ "@babel/parser": "^7.12.7",
+ "@babel/types": "^7.12.7",
"ast-pretty-print": "^2.0.1",
- "babel-plugin-tester": "^9.0.0",
+ "babel-plugin-tester": "^10.0.0",
"babel-plugin-transform-es2015-modules-commonjs": "^6.26.2",
- "cpy": "^8.1.0",
- "kcd-scripts": "^5.6.0"
+ "cpy": "^8.1.1",
+ "kcd-scripts": "^7.1.0"
},
"eslintConfig": {
"extends": "./node_modules/kcd-scripts/eslint.js"
diff --git a/src/__tests__/__snapshots__/index.js.snap b/src/__tests__/__snapshots__/index.js.snap
index 6f996ba..79fe790 100644
--- a/src/__tests__/__snapshots__/index.js.snap
+++ b/src/__tests__/__snapshots__/index.js.snap
@@ -1,6 +1,6 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP
-exports[`macros Macros are applied in the order respecting plugins order: Macros are applied in the order respecting plugins order 1`] = `
+exports[`unknown plugin Macros are applied in the order respecting plugins order: Macros are applied in the order respecting plugins order 1`] = `
import Wrap from "./fixtures/jsx-id-prefix.macro";
@@ -17,7 +17,7 @@ const bar = Wrap(
`;
-exports[`macros Supports named imports: Supports named imports 1`] = `
+exports[`unknown plugin Supports named imports: Supports named imports 1`] = `
import {css as CSS, styled as STYLED} from './fixtures/emotion.macro'
const red = CSS\`
@@ -38,7 +38,7 @@ const Div = STYLED.div\`composes: background-color: red;
`;
-exports[`macros Works as a JSXElement: Works as a JSXElement 1`] = `
+exports[`unknown plugin Works as a JSXElement: Works as a JSXElement 1`] = `
import MyEval from './fixtures/eval.macro'
const x = 34 + 45
@@ -50,7 +50,7 @@ const x = 79
`;
-exports[`macros appends the npm URL for errors thrown by node modules with a slash: appends the npm URL for errors thrown by node modules with a slash 1`] = `
+exports[`unknown plugin appends the npm URL for errors thrown by node modules with a slash: appends the npm URL for errors thrown by node modules with a slash 1`] = `
import errorThrower from 'babel-plugin-macros-test-error-thrower/macro'
errorThrower('hi')
@@ -61,7 +61,7 @@ Error: babel-plugin-macros-test-error-thrower/macro: not helpful Learn more: htt
`;
-exports[`macros appends the npm URL for errors thrown by node modules: appends the npm URL for errors thrown by node modules 1`] = `
+exports[`unknown plugin appends the npm URL for errors thrown by node modules: appends the npm URL for errors thrown by node modules 1`] = `
import errorThrower from 'babel-plugin-macros-test-error-thrower.macro'
errorThrower('hi')
@@ -72,7 +72,7 @@ Error: babel-plugin-macros-test-error-thrower.macro: not helpful Learn more: htt
`;
-exports[`macros does nothing but remove macros if it is unused: does nothing but remove macros if it is unused 1`] = `
+exports[`unknown plugin does nothing but remove macros if it is unused: does nothing but remove macros if it is unused 1`] = `
import foo from "./fixtures/eval.macro";
@@ -85,7 +85,7 @@ const bar = 42
`;
-exports[`macros forwards MacroErrors thrown by the macro: forwards MacroErrors thrown by the macro 1`] = `
+exports[`unknown plugin forwards MacroErrors thrown by the macro: forwards MacroErrors thrown by the macro 1`] = `
import errorThrower from './fixtures/macro-error-thrower.macro'
errorThrower('hey')
@@ -96,7 +96,7 @@ MacroError: very helpful
`;
-exports[`macros macros can set their configName and get their config: macros can set their configName and get their config 1`] = `
+exports[`unknown plugin macros can set their configName and get their config: macros can set their configName and get their config 1`] = `
import configured from './configurable.macro'
@@ -111,7 +111,7 @@ configured\`stuff\`
`;
-exports[`macros optionally keep imports (import declaration): optionally keep imports (import declaration) 1`] = `
+exports[`unknown plugin optionally keep imports (import declaration): optionally keep imports (import declaration) 1`] = `
import macro from './fixtures/keep-imports.macro'
const red = macro('noop');
@@ -124,7 +124,7 @@ const red = macro('noop')
`;
-exports[`macros optionally keep imports (variable assignment): optionally keep imports (variable assignment) 1`] = `
+exports[`unknown plugin optionally keep imports (variable assignment): optionally keep imports (variable assignment) 1`] = `
const macro = require('./fixtures/keep-imports.macro')
const red = macro('noop');
@@ -138,7 +138,7 @@ const red = macro('noop')
`;
-exports[`macros optionally keep imports in combination with babel-preset-env (#80): optionally keep imports in combination with babel-preset-env (#80) 1`] = `
+exports[`unknown plugin optionally keep imports in combination with babel-preset-env (#80): optionally keep imports in combination with babel-preset-env (#80) 1`] = `
import macro from './fixtures/keep-imports.macro'
const red = macro('noop')
@@ -160,7 +160,7 @@ const red = (0, _keepImports2.default)('noop')
`;
-exports[`macros prepends the relative path for errors thrown by the macro: prepends the relative path for errors thrown by the macro 1`] = `
+exports[`unknown plugin prepends the relative path for errors thrown by the macro: prepends the relative path for errors thrown by the macro 1`] = `
import errorThrower from './fixtures/error-thrower.macro'
errorThrower('hey')
@@ -171,7 +171,7 @@ Error: ./fixtures/error-thrower.macro: very unhelpful
`;
-exports[`macros raises an error if macro does not exist: raises an error if macro does not exist 1`] = `
+exports[`unknown plugin raises an error if macro does not exist: raises an error if macro does not exist 1`] = `
import foo from './some-macros-that-doesnt-even-need-to-exist.macro'
export default 'something else'
@@ -182,7 +182,7 @@ Error: Cannot find module './some-macros-that-doesnt-even-need-to-exist.macro' f
`;
-exports[`macros supports compiled macros (\`__esModule\` + \`export default\`): supports compiled macros (\`__esModule\` + \`export default\`) 1`] = `
+exports[`unknown plugin supports compiled macros (\`__esModule\` + \`export default\`): supports compiled macros (\`__esModule\` + \`export default\`) 1`] = `
import {css, styled} from './fixtures/emotion-esm.macro'
const red = css\`
@@ -207,7 +207,7 @@ const Div = styled.div\`
`;
-exports[`macros supports macros from node_modules: supports macros from node_modules 1`] = `
+exports[`unknown plugin supports macros from node_modules: supports macros from node_modules 1`] = `
import fakeMacro from 'babel-plugin-macros-test-fake/macro'
fakeMacro('hi')
@@ -219,7 +219,7 @@ fakeMacro('hi')
`;
-exports[`macros throws an error if the macro is not properly wrapped: throws an error if the macro is not properly wrapped 1`] = `
+exports[`unknown plugin throws an error if the macro is not properly wrapped: throws an error if the macro is not properly wrapped 1`] = `
import unwrapped from './fixtures/non-wrapped.macro'
unwrapped('hey')
@@ -230,7 +230,7 @@ Error: The macro imported from "./fixtures/non-wrapped.macro" must be wrapped in
`;
-exports[`macros when a custom isMacrosName option is used on a import: when a custom isMacrosName option is used on a import 1`] = `
+exports[`unknown plugin when a custom isMacrosName option is used on a import: when a custom isMacrosName option is used on a import 1`] = `
import myEval from './fixtures/eval-macro.js'
const x = myEval\`34 + 45\`
@@ -242,7 +242,7 @@ const x = 79
`;
-exports[`macros when a custom isMacrosName option is used on a require: when a custom isMacrosName option is used on a require 1`] = `
+exports[`unknown plugin when a custom isMacrosName option is used on a require: when a custom isMacrosName option is used on a require 1`] = `
const evaler = require('./fixtures/eval-macro.js')
const x = evaler\`34 + 45\`
@@ -254,7 +254,7 @@ const x = 79
`;
-exports[`macros when a plugin that replaces paths is used, macros still work properly: when a plugin that replaces paths is used, macros still work properly 1`] = `
+exports[`unknown plugin when a plugin that replaces paths is used, macros still work properly: when a plugin that replaces paths is used, macros still work properly 1`] = `
import myEval from '../eval.macro'
@@ -270,7 +270,7 @@ global.result = result
`;
-exports[`macros when configuration is specified in plugin options: when configuration is specified in plugin options 1`] = `
+exports[`unknown plugin when configuration is specified in plugin options: when configuration is specified in plugin options 1`] = `
import configured from './configurable.macro'
@@ -285,7 +285,7 @@ configured\`stuff\`
`;
-exports[`macros when configuration is specified in plugin options: when configuration is specified in plugin options 2`] = `
+exports[`unknown plugin when configuration is specified in plugin options: when configuration is specified in plugin options 2`] = `
const configured = require('./configurable.macro')
@@ -300,7 +300,7 @@ configured\`stuff\`
`;
-exports[`macros when configuration is specified incorrectly in plugin options: when configuration is specified incorrectly in plugin options 1`] = `
+exports[`unknown plugin when configuration is specified incorrectly in plugin options: when configuration is specified incorrectly in plugin options 1`] = `
import configured from './configurable.macro'
@@ -315,7 +315,7 @@ configured\`stuff\`
`;
-exports[`macros when plugin options configuration cannot be merged with file configuration: when plugin options configuration cannot be merged with file configuration 1`] = `
+exports[`unknown plugin when plugin options configuration cannot be merged with file configuration: when plugin options configuration cannot be merged with file configuration 1`] = `
import configured from './configurable.macro'
@@ -328,13 +328,13 @@ Error: /src/__tests__/fixtures/primitive-config/babel-plugin-macro
`;
-exports[`macros when there is an error reading the config, a helpful message is logged 1`] = `
+exports[`unknown plugin when there is an error reading the config, a helpful message is logged 1`] = `
Array [
There was an error trying to load the config "configurableMacro" for the macro imported from "./configurable.macro. Please see the error thrown for more information.,
]
`;
-exports[`macros when there is an error reading the config, a helpful message is logged: when there is an error reading the config, a helpful message is logged 1`] = `
+exports[`unknown plugin when there is an error reading the config, a helpful message is logged: when there is an error reading the config, a helpful message is logged 1`] = `
import configured from './configurable.macro'
@@ -347,7 +347,7 @@ Error: this is a cosmiconfig error
`;
-exports[`macros when there is no config to load, then no config is passed: when there is no config to load, then no config is passed 1`] = `
+exports[`unknown plugin when there is no config to load, then no config is passed: when there is no config to load, then no config is passed 1`] = `
import configured from './configurable.macro'
@@ -362,7 +362,7 @@ configured\`stuff\`
`;
-exports[`macros works with function calls: works with function calls 1`] = `
+exports[`unknown plugin works with function calls: works with function calls 1`] = `
import myEval from './fixtures/eval.macro'
const x = myEval('34 + 45')
@@ -374,7 +374,7 @@ const x = 79
`;
-exports[`macros works with import: works with import 1`] = `
+exports[`unknown plugin works with import: works with import 1`] = `
import myEval from './fixtures/eval.macro'
const x = myEval\`34 + 45\`
@@ -386,7 +386,7 @@ const x = 79
`;
-exports[`macros works with require destructuring and aliasing: works with require destructuring and aliasing 1`] = `
+exports[`unknown plugin works with require destructuring and aliasing: works with require destructuring and aliasing 1`] = `
const {css: CSS, styled: STYLED} = require('./fixtures/emotion.macro')
const red = CSS\`
@@ -407,7 +407,7 @@ const Div = STYLED.div\`composes: background-color: red;
`;
-exports[`macros works with require destructuring: works with require destructuring 1`] = `
+exports[`unknown plugin works with require destructuring: works with require destructuring 1`] = `
const {css, styled} = require('./fixtures/emotion.macro')
const red = css\`
@@ -428,7 +428,7 @@ const Div = styled.div\`composes: background-color: red;
`;
-exports[`macros works with require: works with require 1`] = `
+exports[`unknown plugin works with require: works with require 1`] = `
const evaler = require('./fixtures/eval.macro')
const x = evaler\`34 + 45\`
diff --git a/src/__tests__/fixtures/config/configurable.macro.js b/src/__tests__/fixtures/config/configurable.macro.js
index 83b0840..8836c5b 100644
--- a/src/__tests__/fixtures/config/configurable.macro.js
+++ b/src/__tests__/fixtures/config/configurable.macro.js
@@ -1,4 +1,4 @@
-const {createMacro} = require('../../../../')
+const {createMacro} = require('../../..')
const configName = 'configurableMacro'
const realMacro = jest.fn()
diff --git a/src/__tests__/fixtures/primitive-config/configurable.macro.js b/src/__tests__/fixtures/primitive-config/configurable.macro.js
index 83b0840..8836c5b 100644
--- a/src/__tests__/fixtures/primitive-config/configurable.macro.js
+++ b/src/__tests__/fixtures/primitive-config/configurable.macro.js
@@ -1,4 +1,4 @@
-const {createMacro} = require('../../../../')
+const {createMacro} = require('../../..')
const configName = 'configurableMacro'
const realMacro = jest.fn()
diff --git a/src/index.js b/src/index.js
index ffe3f6f..e2128a9 100644
--- a/src/index.js
+++ b/src/index.js
@@ -74,6 +74,9 @@ function nodeResolvePath(source, basedir) {
function macrosPlugin(
babel,
+ // istanbul doesn't like the default of an object for the plugin options
+ // but I think older versions of babel didn't always pass options
+ // istanbul ignore next
{
require: _require = require,
resolvePath = nodeResolvePath,