react-native/local-cli/link/__tests__/ios/getHeaderSearchPath.spec.js
Mike Grabowski 0af640bfae Further RNPM integration
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
2016-08-22 08:58:37 -07:00

60 lines
2.0 KiB
JavaScript

'use strict';
jest.autoMockOff();
const getHeaderSearchPath = require('../../ios/getHeaderSearchPath');
const path = require('path');
const SRC_DIR = path.join('react-native-project', 'ios');
describe('ios::getHeaderSearchPath', () => {
/**
* See https://github.com/Microsoft/react-native-code-push
*/
it('should return correct path when all headers are in root folder', () => {
const files = [
path.join('react-native-project', 'node_modules', 'package', 'Gradient.h'),
path.join('react-native-project', 'node_modules', 'package', 'Manager.h'),
];
const searchPath = getHeaderSearchPath(SRC_DIR, files);
expect(searchPath).toBe(
`"${['$(SRCROOT)', '..', 'node_modules', 'package'].join(path.sep)}"`
);
});
/**
* See https://github.com/facebook/react-native/tree/master/React
*/
it('should return correct path when headers are in multiple folders', () => {
const files = [
path.join('react-native-project', 'node_modules', 'package', 'src', 'folderA', 'Gradient.h'),
path.join('react-native-project', 'node_modules', 'package', 'src', 'folderB', 'Manager.h'),
];
const searchPath = getHeaderSearchPath(SRC_DIR, files);
expect(searchPath).toBe(
`"${['$(SRCROOT)', '..', 'node_modules', 'package', 'src'].join(path.sep)}/**"`
);
});
/**
* This is just to make sure the above two does not collide with each other
*/
it('should return correct path when headers are in root and nested folders', () => {
const files = [
path.join('react-native-project', 'node_modules', 'package', 'src', 'folderA', 'Gradient.h'),
path.join('react-native-project', 'node_modules', 'package', 'src', 'folderB', 'Manager.h'),
path.join('react-native-project', 'node_modules', 'package', 'src', 'Manager.h'),
];
const searchPath = getHeaderSearchPath(SRC_DIR, files);
expect(searchPath).toBe(
`"${['$(SRCROOT)', '..', 'node_modules', 'package', 'src'].join(path.sep)}/**"`
);
});
});