graphql-compose-mongoose
Version:
Plugin for `graphql-compose` which derive a graphql types from a mongoose model.
134 lines (125 loc) • 5.02 kB
JavaScript
;
var _graphqlCompose = require("graphql-compose");
var _userModel = require("../../__mocks__/userModel");
var _findMany = _interopRequireDefault(require("../findMany"));
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('findMany() ->', () => {
let UserTC;
beforeEach(() => {
_graphqlCompose.schemaComposer.clear();
UserTC = (0, _fieldsConverter.convertModelToGraphQL)(_userModel.UserModel, 'User', _graphqlCompose.schemaComposer);
});
let user1;
let user2;
beforeEach(
/*#__PURE__*/
_asyncToGenerator(function* () {
yield _userModel.UserModel.remove({});
user1 = new _userModel.UserModel({
name: 'userName1',
skills: ['js', 'ruby', 'php', 'python'],
gender: 'male',
relocation: true
});
user2 = new _userModel.UserModel({
name: 'userName2',
skills: ['go', 'erlang'],
gender: 'female',
relocation: false
});
yield Promise.all([user1.save(), user2.save()]);
}));
it('should return Resolver object', () => {
const resolver = (0, _findMany.default)(_userModel.UserModel, UserTC);
expect(resolver).toBeInstanceOf(_graphqlCompose.Resolver);
});
it('Resolver object should have `filter` arg', () => {
const resolver = (0, _findMany.default)(_userModel.UserModel, UserTC);
expect(resolver.hasArg('filter')).toBe(true);
});
it('Resolver object should have `limit` arg', () => {
const resolver = (0, _findMany.default)(_userModel.UserModel, UserTC);
expect(resolver.hasArg('limit')).toBe(true);
});
it('Resolver object should have `skip` arg', () => {
const resolver = (0, _findMany.default)(_userModel.UserModel, UserTC);
expect(resolver.hasArg('skip')).toBe(true);
});
it('Resolver object should have `sort` arg', () => {
const resolver = (0, _findMany.default)(_userModel.UserModel, UserTC);
expect(resolver.hasArg('sort')).toBe(true);
});
describe('Resolver.resolve():Promise', () => {
it('should be fulfilled Promise',
/*#__PURE__*/
_asyncToGenerator(function* () {
const result = (0, _findMany.default)(_userModel.UserModel, UserTC).resolve({});
yield expect(result).resolves.toBeDefined();
}));
it('should return array of documents if args is empty',
/*#__PURE__*/
_asyncToGenerator(function* () {
const result = yield (0, _findMany.default)(_userModel.UserModel, UserTC).resolve({});
expect(result).toBeInstanceOf(Array);
expect(result).toHaveLength(2);
expect(result.map(d => d.name)).toEqual(expect.arrayContaining([user1.name, user2.name]));
}));
it('should limit records',
/*#__PURE__*/
_asyncToGenerator(function* () {
const result = yield (0, _findMany.default)(_userModel.UserModel, UserTC).resolve({
args: {
limit: 1
}
});
expect(result).toBeInstanceOf(Array);
expect(result).toHaveLength(1);
}));
it('should skip records',
/*#__PURE__*/
_asyncToGenerator(function* () {
const result = yield (0, _findMany.default)(_userModel.UserModel, UserTC).resolve({
args: {
skip: 1000
}
});
expect(result).toBeInstanceOf(Array);
expect(result).toHaveLength(0);
}));
it('should sort records',
/*#__PURE__*/
_asyncToGenerator(function* () {
const result1 = yield (0, _findMany.default)(_userModel.UserModel, UserTC).resolve({
args: {
sort: {
_id: 1
}
}
});
const result2 = yield (0, _findMany.default)(_userModel.UserModel, UserTC).resolve({
args: {
sort: {
_id: -1
}
}
});
expect(`${result1[0]._id}`).not.toBe(`${result2[0]._id}`);
}));
it('should return mongoose documents',
/*#__PURE__*/
_asyncToGenerator(function* () {
const result = yield (0, _findMany.default)(_userModel.UserModel, UserTC).resolve({
args: {
limit: 2
}
});
expect(result[0]).toBeInstanceOf(_userModel.UserModel);
expect(result[1]).toBeInstanceOf(_userModel.UserModel);
}));
});
});