UNPKG

graphql-compose-mongoose

Version:

Plugin for `graphql-compose` which derive a graphql types from a mongoose model.

208 lines (193 loc) 7.86 kB
"use strict"; var _graphqlCompose = require("graphql-compose"); var _graphql = require("graphql-compose/lib/graphql"); var _userModel = require("../../__mocks__/userModel"); var _removeById = _interopRequireDefault(require("../removeById")); var _mongoid = _interopRequireDefault(require("../../types/mongoid")); var _fieldsConverter = require("../../fieldsConverter"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } beforeAll(() => _userModel.UserModel.base.connect()); afterAll(() => _userModel.UserModel.base.disconnect()); describe('removeById() ->', () => { let UserTC; beforeEach(() => { _graphqlCompose.schemaComposer.clear(); UserTC = (0, _fieldsConverter.convertModelToGraphQL)(_userModel.UserModel, 'User', _graphqlCompose.schemaComposer); UserTC.setRecordIdFn(source => source ? `${source._id}` : ''); }); let user; beforeEach( /*#__PURE__*/ _asyncToGenerator(function* () { yield _userModel.UserModel.remove({}); user = new _userModel.UserModel({ name: 'userName1', skills: ['js', 'ruby', 'php', 'python'], gender: 'male', relocation: true }); yield user.save(); })); it('should return Resolver object', () => { const resolver = (0, _removeById.default)(_userModel.UserModel, UserTC); expect(resolver).toBeInstanceOf(_graphqlCompose.Resolver); }); describe('Resolver.args', () => { it('should have non-null `_id` arg', () => { const resolver = (0, _removeById.default)(_userModel.UserModel, UserTC); expect(resolver.hasArg('_id')).toBe(true); const argConfig = resolver.getArgConfig('_id'); expect(argConfig.type).toBeInstanceOf(_graphql.GraphQLNonNull); expect(argConfig.type.ofType).toBe(_mongoid.default); }); }); describe('Resolver.resolve():Promise', () => { it('should be promise', () => { const result = (0, _removeById.default)(_userModel.UserModel, UserTC).resolve({}); expect(result).toBeInstanceOf(Promise); result.catch(() => 'catch error if appear, hide it from mocha'); }); it('should rejected with Error if args._id is empty', /*#__PURE__*/ _asyncToGenerator(function* () { const result = (0, _removeById.default)(_userModel.UserModel, UserTC).resolve({ args: {} }); yield expect(result).rejects.toMatchSnapshot(); })); it('should return payload.recordId', /*#__PURE__*/ _asyncToGenerator(function* () { const result = yield (0, _removeById.default)(_userModel.UserModel, UserTC).resolve({ args: { _id: user.id } }); expect(result.recordId).toBe(user.id); })); it('should remove document in database', /*#__PURE__*/ _asyncToGenerator(function* () { yield (0, _removeById.default)(_userModel.UserModel, UserTC).resolve({ args: { _id: user.id } }); yield expect(_userModel.UserModel.findOne({ _id: user._id })).resolves.toBeNull(); })); it('should return payload.record', /*#__PURE__*/ _asyncToGenerator(function* () { const result = yield (0, _removeById.default)(_userModel.UserModel, UserTC).resolve({ args: { _id: user.id } }); expect(result.record.id).toBe(user.id); })); it('should pass empty projection to findById and got full document data', /*#__PURE__*/ _asyncToGenerator(function* () { const result = yield (0, _removeById.default)(_userModel.UserModel, UserTC).resolve({ args: { _id: user.id }, projection: { record: { name: true } } }); expect(result.record.id).toBe(user.id); expect(result.record.name).toBe(user.name); expect(result.record.gender).toBe(user.gender); })); it('should return mongoose document', /*#__PURE__*/ _asyncToGenerator(function* () { const result = yield (0, _removeById.default)(_userModel.UserModel, UserTC).resolve({ args: { _id: user.id } }); expect(result.record).toBeInstanceOf(_userModel.UserModel); })); it('should call `beforeRecordMutate` method with founded `record` and `resolveParams` as args', /*#__PURE__*/ _asyncToGenerator(function* () { let beforeMutationId; const result = yield (0, _removeById.default)(_userModel.UserModel, UserTC).resolve({ args: { _id: user.id }, context: { ip: '1.1.1.1' }, beforeRecordMutate: (record, rp) => { beforeMutationId = record.id; record.someDynamic = rp.context.ip; return record; } }); expect(result.record).toBeInstanceOf(_userModel.UserModel); expect(result.record.someDynamic).toBe('1.1.1.1'); expect(beforeMutationId).toBe(user.id); const empty = yield _userModel.UserModel.collection.findOne({ _id: user._id }); expect(empty).toBe(null); })); it('`beforeRecordMutate` may reject operation', /*#__PURE__*/ _asyncToGenerator(function* () { const result = (0, _removeById.default)(_userModel.UserModel, UserTC).resolve({ args: { _id: user.id }, context: { readOnly: true }, beforeRecordMutate: (record, rp) => { if (rp.context.readOnly) { return Promise.reject(new Error('Denied due context ReadOnly')); } return record; } }); yield expect(result).rejects.toMatchSnapshot(); const exist = yield _userModel.UserModel.collection.findOne({ _id: user._id }); expect(exist.name).toBe(user.name); })); }); describe('Resolver.getType()', () => { it('should have correct output type name', () => { const outputType = (0, _removeById.default)(_userModel.UserModel, UserTC).getType(); expect(outputType.name).toBe(`RemoveById${UserTC.getTypeName()}Payload`); }); it('should have recordId field', () => { const outputType = (0, _removeById.default)(_userModel.UserModel, UserTC).getType(); const typeComposer = new _graphqlCompose.TypeComposer(outputType); expect(typeComposer.hasField('recordId')).toBe(true); expect(typeComposer.getFieldType('recordId')).toBe(_mongoid.default); }); it('should have record field', () => { const outputType = (0, _removeById.default)(_userModel.UserModel, UserTC).getType(); const typeComposer = new _graphqlCompose.TypeComposer(outputType); expect(typeComposer.hasField('record')).toBe(true); expect(typeComposer.getFieldType('record')).toBe(UserTC.getType()); }); it('should reuse existed outputType', () => { const outputTypeName = `RemoveById${UserTC.getTypeName()}Payload`; const existedType = _graphqlCompose.TypeComposer.create(outputTypeName); _graphqlCompose.schemaComposer.set(outputTypeName, existedType); const outputType = (0, _removeById.default)(_userModel.UserModel, UserTC).getType(); expect(outputType).toBe(existedType.getType()); }); }); });