2016-07-30 08:59:16 -07:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
jest.autoMockOff();
|
|
|
|
|
2016-05-20 04:52:08 -07:00
|
|
|
const xcode = require('xcode');
|
2016-07-30 08:59:16 -07:00
|
|
|
const path = require('path');
|
2016-08-22 08:56:14 -07:00
|
|
|
const createGroup = require('../../ios/createGroup');
|
|
|
|
const getGroup = require('../../ios/getGroup');
|
2016-05-20 04:52:08 -07:00
|
|
|
const last = require('lodash').last;
|
|
|
|
|
2016-07-30 08:59:16 -07:00
|
|
|
const project = xcode.project(
|
|
|
|
path.join(__dirname, '../../__fixtures__/project.pbxproj')
|
|
|
|
);
|
2016-05-20 04:52:08 -07:00
|
|
|
|
|
|
|
describe('ios::createGroup', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
project.parseSync();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should create a group with given name', () => {
|
|
|
|
const createdGroup = createGroup(project, 'Resources');
|
2016-07-30 08:59:16 -07:00
|
|
|
expect(createdGroup.name).toBe('Resources');
|
2016-05-20 04:52:08 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should attach group to main project group', () => {
|
|
|
|
const createdGroup = createGroup(project, 'Resources');
|
|
|
|
const mainGroup = getGroup(project);
|
|
|
|
|
|
|
|
expect(
|
|
|
|
last(mainGroup.children).comment
|
2016-07-30 08:59:16 -07:00
|
|
|
).toBe(createdGroup.name);
|
2016-05-20 04:52:08 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should create a nested group with given path', () => {
|
|
|
|
const createdGroup = createGroup(project, 'NewGroup/NewNestedGroup');
|
|
|
|
const outerGroup = getGroup(project, 'NewGroup');
|
|
|
|
|
|
|
|
expect(
|
|
|
|
last(outerGroup.children).comment
|
2016-07-30 08:59:16 -07:00
|
|
|
).toBe(createdGroup.name);
|
2016-05-20 04:52:08 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should-not create already created groups', () => {
|
|
|
|
const createdGroup = createGroup(project, 'Libraries/NewNestedGroup');
|
|
|
|
const outerGroup = getGroup(project, 'Libraries');
|
|
|
|
const mainGroup = getGroup(project);
|
|
|
|
|
|
|
|
expect(
|
2016-07-30 08:59:16 -07:00
|
|
|
mainGroup
|
|
|
|
.children
|
|
|
|
.filter(group => group.comment === 'Libraries')
|
|
|
|
.length
|
|
|
|
).toBe(1);
|
|
|
|
expect(last(outerGroup.children).comment).toBe(createdGroup.name);
|
2016-05-20 04:52:08 -07:00
|
|
|
});
|
|
|
|
});
|