mirror of
https://github.com/zhigang1992/react-native.git
synced 2026-06-18 06:58:48 +08:00
Summary: This is an initial step of rewriting the CLI interface to use `rnpm` one (commander, plugins etc.). It's scope is to move all existing commands to use rnpm CLI interface, so that we get plugins, flags and our existing ecosystem working out of the box. <s>This is still WIP and some of the commands are left commented out.</s> For the `config` of `rnpm` (functions get info about project and dependency), <s>I am thinking we can merge them with</s> we decided to merge it with [`default.config.js`](e57683e420/local-cli/default.config.js (L33)), so they are available on the `new Config()` [instance](e57683e420/local-cli/cliEntry.js (L59)) (which means we don't have to change anything and current plugins, like runIOS and runAndroid can just start using it [w/o depending on any extra argument](https://github.com/grabbou/react-native/blob/e57683e420210749a5a6b802b4e Closes https://github.com/facebook/react-native/pull/7899 Differential Revision: D3613193 Pulled By: bestander fbshipit-source-id: 09a072f3b21e5239dfcd8da88a205bd28dc5d037
42 lines
1.2 KiB
JavaScript
42 lines
1.2 KiB
JavaScript
'use strict';
|
|
|
|
jest.autoMockOff();
|
|
|
|
const xcode = require('xcode');
|
|
const getGroup = require('../../src/ios/getGroup');
|
|
const path = require('path');
|
|
|
|
const project = xcode.project(
|
|
path.join(__dirname, '../../__fixtures__/project.pbxproj')
|
|
);
|
|
|
|
describe('ios::getGroup', () => {
|
|
beforeEach(() => {
|
|
project.parseSync();
|
|
});
|
|
|
|
it('should return a top-level group', () => {
|
|
const group = getGroup(project, 'Libraries');
|
|
expect(group.children.length > 0).toBeTruthy();
|
|
expect(group.name).toBe('Libraries');
|
|
});
|
|
|
|
it('should return nested group when specified', () => {
|
|
const group = getGroup(project, 'NestedGroup/Libraries');
|
|
expect(group.children.length).toBe(0); // our test nested Libraries is empty
|
|
expect(group.name).toBe('Libraries');
|
|
});
|
|
|
|
it('should return null when no group found', () => {
|
|
const group = getGroup(project, 'I-Dont-Exist');
|
|
expect(group).toBeNull();
|
|
});
|
|
|
|
it('should return top-level group when name not specified', () => {
|
|
const mainGroupId = project.getFirstProject().firstProject.mainGroup;
|
|
const mainGroup = project.getPBXGroupByKey(mainGroupId);
|
|
const group = getGroup(project);
|
|
expect(group).toEqual(mainGroup);
|
|
});
|
|
});
|