UNPKG

@rest-api/react-models

Version:

[![npm version](https://img.shields.io/npm/v/@rest-api/react-models)](https://www.npmjs.com/package/@rest-api/react-models) [![codecov](https://codecov.io/gh/hector7/rest-api-react-models/branch/master/graph/badge.svg)](https://codecov.io/gh/hector7/rest-

65 lines (64 loc) 3.32 kB
"use strict"; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); const bookModelOtherUrlExtended_1 = __importDefault(require("./bookModelOtherUrlExtended")); const react_1 = __importDefault(require("react")); const react_2 = require("@testing-library/react"); const __1 = require("../../.."); const fake_xml_http_request_1 = __importDefault(require("fake-xml-http-request")); describe('getSearchSubmodelExtended', () => { test('useGet works', (d) => { function LibraryComponentGet() { const result = bookModelOtherUrlExtended_1.default.useGet({ project: 'test' }); return react_1.default.createElement(react_1.default.Fragment, null, result.items.map(i => react_1.default.createElement("p", { key: i.id }, i.name))); } global.XMLHttpRequest = class XMLHttpRequest extends fake_xml_http_request_1.default { send() { switch (this.responseURL) { case '/api/extended/test': setTimeout(() => { this.respond(200, {}, JSON.stringify([{ id: 1, name: 'pepita', library: 1 }])); }, 40); } } }; const Provider = __1.getProvider(); const { getByText } = react_2.render(react_1.default.createElement(Provider, null, react_1.default.createElement(LibraryComponentGet, null))); setTimeout(() => { getByText(/pepita/i); d(); }, 60); }); test('useGetPopulated works', (d) => { function LibraryComponentGetPopulated() { const result = bookModelOtherUrlExtended_1.default.useGetPopulated({ project: 'test' }); return react_1.default.createElement(react_1.default.Fragment, null, result.populated && result.items.map(i => { var _a; return react_1.default.createElement("p", { key: i.id }, (_a = i.library) === null || _a === void 0 ? void 0 : _a.name); }), !result.populated && result.items.map(i => { var _a; return react_1.default.createElement("p", { key: i.id }, (_a = i.library) === null || _a === void 0 ? void 0 : _a.name); })); } global.XMLHttpRequest = class XMLHttpRequest extends fake_xml_http_request_1.default { send() { switch (this.responseURL) { case '/api/extended/test': return setTimeout(() => { this.respond(200, {}, JSON.stringify([{ id: 1, name: 'book', library: 1 }])); }, 10); case '/api/library/1/': return setTimeout(() => { this.respond(200, {}, JSON.stringify({ id: 1, name: 'book' })); }, 10); } } }; const Provider = __1.getProvider(); const { getByText, container } = react_2.render(react_1.default.createElement(Provider, null, react_1.default.createElement(LibraryComponentGetPopulated, null))); setTimeout(() => { getByText(/book/i); d(); }, 60); }); });