mirror of
https://github.com/status-im/react-native.git
synced 2025-01-17 13:01:13 +00:00
149d0b91c2
Summary: This is initial (first step) in the merging process. For now, we are just going to move our code as is into `local-cli` folder (first commit). There were other tweaks made in separate commits to make it easier to go through the code as the diff is expected to be rather large. The purpose of this is to make it easier to start working in small batches and improving the CLI incrementally on a daily basis. Current codebase will still leave in `rnpm` organisation on Github where we keep working on new features, bugs and ship releases to `npm` until we finish our integration and provide a nice interface for users to migrate (in case it changes at all) Flow, Jest and npm will ignore this folder for now until we integrate it properly. Tests are to be rewritten from mocha to jest in `rnpm/link`. We will hook them all up as soon as we start using them in local-cli. For now, there's no point in having them running and possibly breaking the builds. We will announce next steps with Kureev later this week Closes https://github.com/facebook/react-native/pull/7550 Differential Revision: D3327772 Pulled By: mkonicek fbshipit-source-id: 90faa4bd78476d93ed21b1253e0d95c755d28a30
85 lines
2.1 KiB
JavaScript
85 lines
2.1 KiB
JavaScript
jest.autoMockOff();
|
|
|
|
const findProject = require('../../src/config/ios/findProject');
|
|
const mockFs = require('mock-fs');
|
|
const projects = require('../fixtures/projects');
|
|
const ios = require('../fixtures/ios');
|
|
const userConfig = {};
|
|
|
|
describe('ios::findProject', () => {
|
|
it('should return path to xcodeproj if found', () => {
|
|
mockFs(projects.flat);
|
|
expect(findProject('')).not.toBe(null);
|
|
});
|
|
|
|
it('should return null if there\'re no projects', () => {
|
|
mockFs({ testDir: projects });
|
|
expect(findProject('')).toBe(null);
|
|
});
|
|
|
|
it('should return ios project regardless of its name', () => {
|
|
mockFs({ ios: ios.validTestName });
|
|
expect(findProject('')).not.toBe(null);
|
|
});
|
|
|
|
it('should ignore node_modules', () => {
|
|
mockFs({ node_modules: projects.flat });
|
|
expect(findProject('')).toBe(null);
|
|
});
|
|
|
|
it('should ignore Pods', () => {
|
|
mockFs({ Pods: projects.flat });
|
|
expect(findProject('')).toBe(null);
|
|
});
|
|
|
|
it('should ignore Pods inside `ios` folder', () => {
|
|
mockFs({
|
|
ios: {
|
|
Pods: projects.flat,
|
|
DemoApp: projects.flat.ios,
|
|
},
|
|
});
|
|
expect(findProject('')).toBe('ios/DemoApp/demoProject.xcodeproj');
|
|
});
|
|
|
|
it('should ignore xcodeproj from example folders', () => {
|
|
mockFs({
|
|
examples: projects.flat,
|
|
Examples: projects.flat,
|
|
example: projects.flat,
|
|
KeychainExample: projects.flat,
|
|
Zpp: projects.flat,
|
|
});
|
|
|
|
expect(findProject('').toLowerCase()).not.toContain('example');
|
|
});
|
|
|
|
it('should ignore xcodeproj from sample folders', () => {
|
|
mockFs({
|
|
samples: projects.flat,
|
|
Samples: projects.flat,
|
|
sample: projects.flat,
|
|
KeychainSample: projects.flat,
|
|
Zpp: projects.flat,
|
|
});
|
|
|
|
expect(findProject('').toLowerCase()).not.toContain('sample');
|
|
});
|
|
|
|
it('should ignore xcodeproj from test folders at any level', () => {
|
|
mockFs({
|
|
test: projects.flat,
|
|
IntegrationTests: projects.flat,
|
|
tests: projects.flat,
|
|
Zpp: {
|
|
tests: projects.flat,
|
|
src: projects.flat,
|
|
},
|
|
});
|
|
|
|
expect(findProject('').toLowerCase()).not.toContain('test');
|
|
});
|
|
|
|
afterEach(mockFs.restore);
|
|
});
|