mirror of
https://github.com/status-im/react-native.git
synced 2025-01-10 01:25:39 +00:00
0af640bfae
Summary: This commit removes `rnpm` folder that we left during initial merge to keep the diff cleaner. The `core`, `link` and `install` have now the same directory structure as any other command to make development more natural for all of us. From most notable differences: 1) the `src` folder is now gone. The new structure should make it easier for people to work with the stuff and also move us closer to 100% rnpm integration, 2) There's also no `package.json` present in any of the `rnpm` packages, since they are no longer standalone modules, 3) There's no `bugs.url` in link.js since main package.json of React doesn't specify it. Decided to hardcode it to facebook/react-native since it's really unlikely to change. If one would prefer to use pkg.bugs.url as before, a separate PR modifying package.json should be sent. Closes https://github.com/facebook/react-native/pull/9509 Differential Revision: D3751115 fbshipit-source-id: 74ae8330f7634df0887ad676808f47eee4b8de85
47 lines
1.5 KiB
JavaScript
47 lines
1.5 KiB
JavaScript
jest.autoMockOff();
|
|
|
|
const path = require('path');
|
|
const findPlugins = require('../findPlugins');
|
|
|
|
const pjsonPath = path.join(process.cwd(), 'package.json');
|
|
const isArray = (arg) =>
|
|
Object.prototype.toString.call(arg) === '[object Array]';
|
|
|
|
describe('findPlugins', () => {
|
|
|
|
it('should return an array of dependencies', () => {
|
|
jest.setMock(pjsonPath, {
|
|
dependencies: { 'rnpm-plugin-test': '*' },
|
|
});
|
|
expect(findPlugins([process.cwd()]).length).toBe(1);
|
|
expect(findPlugins([process.cwd()])[0]).toBe('rnpm-plugin-test');
|
|
});
|
|
|
|
it('should return an empty array if there\'re no plugins in this folder', () => {
|
|
jest.setMock(pjsonPath, {});
|
|
expect(findPlugins([process.cwd()]).length).toBe(0);
|
|
});
|
|
|
|
it('should return an empty array if there\'s no package.json in the supplied folder', () => {
|
|
expect(isArray(findPlugins(['fake-path']))).toBeTruthy();
|
|
expect(findPlugins(['fake-path']).length).toBe(0);
|
|
});
|
|
|
|
it('should return plugins from both dependencies and dev dependencies', () => {
|
|
jest.setMock(pjsonPath, {
|
|
dependencies: { 'rnpm-plugin-test': '*' },
|
|
devDependencies: { 'rnpm-plugin-test-2': '*' },
|
|
});
|
|
expect(findPlugins([process.cwd()]).length).toEqual(2);
|
|
});
|
|
|
|
it('should return unique list of plugins', () => {
|
|
jest.setMock(pjsonPath, {
|
|
dependencies: { 'rnpm-plugin-test': '*' },
|
|
devDependencies: { 'rnpm-plugin-test': '*' },
|
|
});
|
|
expect(findPlugins([process.cwd()]).length).toEqual(1);
|
|
});
|
|
|
|
});
|