wrapito 13.0.0 → 13.1.0-beta2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.cts +33 -15
- package/dist/index.d.ts +33 -15
- package/dist/index.js +7 -7
- package/dist/index.mjs +7 -7
- package/package.json +1 -1
package/dist/index.d.cts
CHANGED
|
@@ -30,14 +30,26 @@ interface WrapResponse extends Partial<Response> {
|
|
|
30
30
|
hasBeenReturned?: boolean;
|
|
31
31
|
}
|
|
32
32
|
type NetworkResponses = WrapResponse | WrapResponse[];
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
33
|
+
type DefaultUserLib = unknown;
|
|
34
|
+
type DefaultUserInstance = unknown;
|
|
35
|
+
type DefaultUserSetupOptions = unknown;
|
|
36
|
+
interface InteractionDescriptor<UserLib = DefaultUserLib, UserInstance = DefaultUserInstance, UserSetupOptions = DefaultUserSetupOptions> {
|
|
37
|
+
UserLib: UserLib;
|
|
38
|
+
UserInstance: UserInstance;
|
|
39
|
+
UserSetupOptions: UserSetupOptions;
|
|
39
40
|
}
|
|
40
|
-
|
|
41
|
+
type MountResult<UserInteraction extends InteractionDescriptor> = UserInteraction['UserInstance'] extends unknown ? RenderResult : RenderResult & {
|
|
42
|
+
user: UserInteraction['UserInstance'];
|
|
43
|
+
};
|
|
44
|
+
interface Wrap<UserInteraction extends InteractionDescriptor = InteractionDescriptor> {
|
|
45
|
+
withNetwork: (responses?: NetworkResponses) => Wrap<UserInteraction>;
|
|
46
|
+
atPath: (path: string, historyState?: object) => Wrap<UserInteraction>;
|
|
47
|
+
withProps: (props: object) => Wrap<UserInteraction>;
|
|
48
|
+
withInteraction: (config: UserInteraction['UserSetupOptions']) => Wrap<UserInteraction>;
|
|
49
|
+
debugRequests: () => Wrap<UserInteraction>;
|
|
50
|
+
mount: () => MountResult<UserInteraction>;
|
|
51
|
+
}
|
|
52
|
+
interface WrapOptions<SetupOptions = DefaultUserSetupOptions> {
|
|
41
53
|
Component: unknown;
|
|
42
54
|
responses: WrapResponse[];
|
|
43
55
|
props: object;
|
|
@@ -45,26 +57,32 @@ interface WrapOptions {
|
|
|
45
57
|
historyState?: object;
|
|
46
58
|
hasPath: boolean;
|
|
47
59
|
debug: boolean;
|
|
60
|
+
interactionConfig?: SetupOptions;
|
|
48
61
|
}
|
|
49
62
|
interface WrapExtensionAPI {
|
|
50
63
|
addResponses: (responses: Array<WrapResponse>) => unknown;
|
|
51
64
|
}
|
|
52
|
-
type Extension = <T>(extensionAPI: WrapExtensionAPI, args: T) => Wrap
|
|
53
|
-
type Extensions = {
|
|
54
|
-
[key: string]: Extension
|
|
65
|
+
type Extension<UserInteraction extends InteractionDescriptor = InteractionDescriptor> = <T>(extensionAPI: WrapExtensionAPI, args: T) => Wrap<UserInteraction>;
|
|
66
|
+
type Extensions<UserInteraction extends InteractionDescriptor = InteractionDescriptor> = {
|
|
67
|
+
[key: string]: Extension<UserInteraction>;
|
|
55
68
|
};
|
|
56
69
|
type Component = React.ReactElement<any, any>;
|
|
57
70
|
type RenderResult = RenderResult$1;
|
|
58
|
-
type Mount = (component: Component) =>
|
|
59
|
-
interface
|
|
71
|
+
type Mount<UserInteraction extends InteractionDescriptor = InteractionDescriptor> = (component: Component) => MountResult<UserInteraction>;
|
|
72
|
+
interface InteractionOptions<UserInteraction extends InteractionDescriptor = InteractionDescriptor> {
|
|
73
|
+
userLib: UserInteraction['UserLib'];
|
|
74
|
+
setup?: (userLib: UserInteraction['UserLib'], options?: UserInteraction['UserSetupOptions']) => UserInteraction['UserInstance'];
|
|
75
|
+
}
|
|
76
|
+
interface Config<UserInteraction extends InteractionDescriptor = InteractionDescriptor> {
|
|
60
77
|
defaultHost: string;
|
|
61
|
-
mount: Mount
|
|
62
|
-
extend: Extensions
|
|
78
|
+
mount: Mount<UserInteraction>;
|
|
79
|
+
extend: Extensions<UserInteraction>;
|
|
63
80
|
changeRoute: (path: string) => void;
|
|
64
81
|
history?: BrowserHistory;
|
|
65
82
|
portal?: string;
|
|
66
83
|
portals?: string[];
|
|
67
84
|
handleQueryParams?: boolean;
|
|
85
|
+
interaction?: InteractionOptions<UserInteraction>;
|
|
68
86
|
}
|
|
69
87
|
interface BrowserHistory extends History {
|
|
70
88
|
push: (path: string, historyState?: object) => void;
|
|
@@ -90,4 +108,4 @@ declare const matchers: {
|
|
|
90
108
|
};
|
|
91
109
|
};
|
|
92
110
|
|
|
93
|
-
export { type BrowserHistory, type Component, type Config, type Extension, type Extensions, type HttpMethod, type Mount, type NetworkResponses, type RenderResult, type RequestOptions, type WrapResponse as Response, type Wrap, type WrapExtensionAPI, type WrapOptions, type WrapRequest, type WrapResponse, matchers as assertions, configure, getConfig, matchers, wrap };
|
|
111
|
+
export { type BrowserHistory, type Component, type Config, type DefaultUserInstance, type DefaultUserLib, type DefaultUserSetupOptions, type Extension, type Extensions, type HttpMethod, type InteractionDescriptor, type InteractionOptions, type Mount, type NetworkResponses, type RenderResult, type RequestOptions, type WrapResponse as Response, type Wrap, type WrapExtensionAPI, type WrapOptions, type WrapRequest, type WrapResponse, matchers as assertions, configure, getConfig, matchers, wrap };
|
package/dist/index.d.ts
CHANGED
|
@@ -30,14 +30,26 @@ interface WrapResponse extends Partial<Response> {
|
|
|
30
30
|
hasBeenReturned?: boolean;
|
|
31
31
|
}
|
|
32
32
|
type NetworkResponses = WrapResponse | WrapResponse[];
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
33
|
+
type DefaultUserLib = unknown;
|
|
34
|
+
type DefaultUserInstance = unknown;
|
|
35
|
+
type DefaultUserSetupOptions = unknown;
|
|
36
|
+
interface InteractionDescriptor<UserLib = DefaultUserLib, UserInstance = DefaultUserInstance, UserSetupOptions = DefaultUserSetupOptions> {
|
|
37
|
+
UserLib: UserLib;
|
|
38
|
+
UserInstance: UserInstance;
|
|
39
|
+
UserSetupOptions: UserSetupOptions;
|
|
39
40
|
}
|
|
40
|
-
|
|
41
|
+
type MountResult<UserInteraction extends InteractionDescriptor> = UserInteraction['UserInstance'] extends unknown ? RenderResult : RenderResult & {
|
|
42
|
+
user: UserInteraction['UserInstance'];
|
|
43
|
+
};
|
|
44
|
+
interface Wrap<UserInteraction extends InteractionDescriptor = InteractionDescriptor> {
|
|
45
|
+
withNetwork: (responses?: NetworkResponses) => Wrap<UserInteraction>;
|
|
46
|
+
atPath: (path: string, historyState?: object) => Wrap<UserInteraction>;
|
|
47
|
+
withProps: (props: object) => Wrap<UserInteraction>;
|
|
48
|
+
withInteraction: (config: UserInteraction['UserSetupOptions']) => Wrap<UserInteraction>;
|
|
49
|
+
debugRequests: () => Wrap<UserInteraction>;
|
|
50
|
+
mount: () => MountResult<UserInteraction>;
|
|
51
|
+
}
|
|
52
|
+
interface WrapOptions<SetupOptions = DefaultUserSetupOptions> {
|
|
41
53
|
Component: unknown;
|
|
42
54
|
responses: WrapResponse[];
|
|
43
55
|
props: object;
|
|
@@ -45,26 +57,32 @@ interface WrapOptions {
|
|
|
45
57
|
historyState?: object;
|
|
46
58
|
hasPath: boolean;
|
|
47
59
|
debug: boolean;
|
|
60
|
+
interactionConfig?: SetupOptions;
|
|
48
61
|
}
|
|
49
62
|
interface WrapExtensionAPI {
|
|
50
63
|
addResponses: (responses: Array<WrapResponse>) => unknown;
|
|
51
64
|
}
|
|
52
|
-
type Extension = <T>(extensionAPI: WrapExtensionAPI, args: T) => Wrap
|
|
53
|
-
type Extensions = {
|
|
54
|
-
[key: string]: Extension
|
|
65
|
+
type Extension<UserInteraction extends InteractionDescriptor = InteractionDescriptor> = <T>(extensionAPI: WrapExtensionAPI, args: T) => Wrap<UserInteraction>;
|
|
66
|
+
type Extensions<UserInteraction extends InteractionDescriptor = InteractionDescriptor> = {
|
|
67
|
+
[key: string]: Extension<UserInteraction>;
|
|
55
68
|
};
|
|
56
69
|
type Component = React.ReactElement<any, any>;
|
|
57
70
|
type RenderResult = RenderResult$1;
|
|
58
|
-
type Mount = (component: Component) =>
|
|
59
|
-
interface
|
|
71
|
+
type Mount<UserInteraction extends InteractionDescriptor = InteractionDescriptor> = (component: Component) => MountResult<UserInteraction>;
|
|
72
|
+
interface InteractionOptions<UserInteraction extends InteractionDescriptor = InteractionDescriptor> {
|
|
73
|
+
userLib: UserInteraction['UserLib'];
|
|
74
|
+
setup?: (userLib: UserInteraction['UserLib'], options?: UserInteraction['UserSetupOptions']) => UserInteraction['UserInstance'];
|
|
75
|
+
}
|
|
76
|
+
interface Config<UserInteraction extends InteractionDescriptor = InteractionDescriptor> {
|
|
60
77
|
defaultHost: string;
|
|
61
|
-
mount: Mount
|
|
62
|
-
extend: Extensions
|
|
78
|
+
mount: Mount<UserInteraction>;
|
|
79
|
+
extend: Extensions<UserInteraction>;
|
|
63
80
|
changeRoute: (path: string) => void;
|
|
64
81
|
history?: BrowserHistory;
|
|
65
82
|
portal?: string;
|
|
66
83
|
portals?: string[];
|
|
67
84
|
handleQueryParams?: boolean;
|
|
85
|
+
interaction?: InteractionOptions<UserInteraction>;
|
|
68
86
|
}
|
|
69
87
|
interface BrowserHistory extends History {
|
|
70
88
|
push: (path: string, historyState?: object) => void;
|
|
@@ -90,4 +108,4 @@ declare const matchers: {
|
|
|
90
108
|
};
|
|
91
109
|
};
|
|
92
110
|
|
|
93
|
-
export { type BrowserHistory, type Component, type Config, type Extension, type Extensions, type HttpMethod, type Mount, type NetworkResponses, type RenderResult, type RequestOptions, type WrapResponse as Response, type Wrap, type WrapExtensionAPI, type WrapOptions, type WrapRequest, type WrapResponse, matchers as assertions, configure, getConfig, matchers, wrap };
|
|
111
|
+
export { type BrowserHistory, type Component, type Config, type DefaultUserInstance, type DefaultUserLib, type DefaultUserSetupOptions, type Extension, type Extensions, type HttpMethod, type InteractionDescriptor, type InteractionOptions, type Mount, type NetworkResponses, type RenderResult, type RequestOptions, type WrapResponse as Response, type Wrap, type WrapExtensionAPI, type WrapOptions, type WrapRequest, type WrapResponse, matchers as assertions, configure, getConfig, matchers, wrap };
|
package/dist/index.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
"use strict";var me=Object.create;var
|
|
2
|
-
${
|
|
3
|
-
${
|
|
4
|
-
${
|
|
5
|
-
${
|
|
6
|
-
`),V=async(e,t,
|
|
1
|
+
"use strict";var me=Object.create;var O=Object.defineProperty;var de=Object.getOwnPropertyDescriptor;var he=Object.getOwnPropertyNames;var fe=Object.getPrototypeOf,ge=Object.prototype.hasOwnProperty;var ye=(e,t)=>{for(var n in t)O(e,n,{get:t[n],enumerable:!0})},j=(e,t,n,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of he(t))!ge.call(e,o)&&o!==n&&O(e,o,{get:()=>t[o],enumerable:!(s=de(t,o))||s.enumerable});return e};var T=(e,t,n)=>(n=e!=null?me(fe(e)):{},j(t||!e||!e.__esModule?O(n,"default",{value:e,enumerable:!0}):n,e)),Re=e=>j(O({},"__esModule",{value:!0}),e);var ze={};ye(ze,{assertions:()=>Ye,configure:()=>Ie,getConfig:()=>d,matchers:()=>Ye,wrap:()=>ve});module.exports=Re(ze);var J=T(require("react"),1);var I=T(require("chalk"),1);var C=T(require("object-hash"),1);var N=require("@testing-library/react"),A={defaultHost:"",extend:{},mount:N.render,changeRoute:e=>window.history.replaceState(null,"",e)};function Ie(e){A={...A,...e}}var d=()=>({...A});var $=e=>t=>{let{method:n="GET",path:s,host:o=d().defaultHost,requestBody:r=void 0,catchParams:a}=t,l=o+s,i=!d().handleQueryParams||a,u=(0,C.default)({url:i?l:l.split("?")[0],method:n.toUpperCase(),requestBody:r}),p;return"_bodyInit"in e&&e._bodyInit!==void 0&&(p=JSON.parse(e._bodyInit)),(0,C.default)({url:i?e.url:e.url.split("?")[0],method:e.method,requestBody:p})===u};function E(e,t){if(!e)throw new Error(t)}function w(e,t){return typeof t===e}function be(e){return e instanceof Promise}function D(e,t,n){Object.defineProperty(e,t,n)}function x(e,t,n){Object.defineProperty(e,t,{value:n})}var M=Symbol.for("tinyspy:spy"),we=new Set,xe=e=>{e.called=!1,e.callCount=0,e.calls=[],e.results=[],e.next=[]},ke=e=>(D(e,M,{value:{reset:()=>xe(e[M])}}),e[M]),U=e=>e[M]||ke(e);function Me(e){E(w("function",e)||w("undefined",e),"cannot spy on a non-function value");let t=function(...s){let o=U(t);o.called=!0,o.callCount++,o.calls.push(s);let r=o.next.shift();if(r){o.results.push(r);let[u,p]=r;if(u==="ok")return p;throw p}let a,l="ok";if(o.impl)try{new.target?a=Reflect.construct(o.impl,s,new.target):a=o.impl.apply(this,s),l="ok"}catch(u){throw a=u,l="error",o.results.push([l,u]),u}let i=[l,a];if(be(a)){let u=a.then(p=>i[1]=p).catch(p=>{throw i[0]="error",i[1]=p,p});Object.assign(u,a),a=u}return o.results.push(i),a};x(t,"_isMockFunction",!0),x(t,"length",e?e.length:0),x(t,"name",e&&e.name||"spy");let n=U(t);return n.reset(),n.impl=e,t}var L=(e,t)=>Object.getOwnPropertyDescriptor(e,t),F=(e,t)=>{t!=null&&typeof t=="function"&&t.prototype!=null&&Object.setPrototypeOf(e.prototype,t.prototype)};function _(e,t,n){E(!w("undefined",e),"spyOn could not find an object to spy upon"),E(w("object",e)||w("function",e),"cannot spyOn on a primitive value");let[s,o]=(()=>{if(!w("object",t))return[t,"value"];if("getter"in t&&"setter"in t)throw new Error("cannot spy on both getter and setter");if("getter"in t)return[t.getter,"get"];if("setter"in t)return[t.setter,"set"];throw new Error("specify getter or setter to spy on")})(),r=L(e,s),a=Object.getPrototypeOf(e),l=a&&L(a,s),i=r||l;E(i||s in e,`${String(s)} does not exist`);let u=!1;o==="value"&&i&&!i.value&&i.get&&(o="get",u=!0,n=i.get());let p;i?p=i[o]:o!=="value"?p=()=>e[s]:p=e[s],n||(n=p);let m=Me(n);o==="value"&&F(m,p);let c=f=>{let{value:k,...v}=i||{configurable:!0,writable:!0};o!=="value"&&delete v.writable,v[o]=f,D(e,s,v)},g=()=>i?D(e,s,i):c(p),h=m[M];return x(h,"restore",g),x(h,"getOriginal",()=>u?p():p),x(h,"willCall",f=>(h.impl=f,m)),c(u?()=>(F(m,n),m):m),we.add(m),m}var Te=new Set,Ee=0;function Ue(e){let t=e,n,s=[],o=[],r=U(e),a={get calls(){return r.calls},get instances(){return s},get invocationCallOrder(){return o},get results(){return r.results.map(([c,g])=>({type:c==="error"?"throw":"return",value:g}))},get lastCall(){return r.calls[r.calls.length-1]}},l=[],i=!1;function u(...c){return s.push(this),o.push(++Ee),(i?n:l.shift()||n||r.getOriginal()||(()=>{})).apply(this,c)}let p=t.name;t.getMockName=()=>p||"vi.fn()",t.mockName=c=>(p=c,t),t.mockClear=()=>(r.reset(),s=[],o=[],t),t.mockReset=()=>(t.mockClear(),n=()=>{},l=[],t),t.mockRestore=()=>(t.mockReset(),r.restore(),n=void 0,t),t.getMockImplementation=()=>n,t.mockImplementation=c=>(n=c,r.willCall(u),t),t.mockImplementationOnce=c=>(l.push(c),t);function m(c,g){let h=n;n=c,r.willCall(u),i=!0;let f=()=>{n=h,i=!1},k=g();return k instanceof Promise?k.then(()=>(f(),t)):(f(),t)}return t.withImplementation=m,t.mockReturnThis=()=>t.mockImplementation(function(){return this}),t.mockReturnValue=c=>t.mockImplementation(()=>c),t.mockReturnValueOnce=c=>t.mockImplementationOnce(()=>c),t.mockResolvedValue=c=>t.mockImplementation(()=>Promise.resolve(c)),t.mockResolvedValueOnce=c=>t.mockImplementationOnce(()=>Promise.resolve(c)),t.mockRejectedValue=c=>t.mockImplementation(()=>Promise.reject(c)),t.mockRejectedValueOnce=c=>t.mockImplementationOnce(()=>Promise.reject(c)),Object.defineProperty(t,"mock",{get:()=>a}),r.willCall(u),Te.add(t),t}var P=e=>Ue(_({spy:e||(()=>{})},"spy"));beforeEach(()=>{global.window.fetch=P()});afterEach(()=>{global.window.fetch.mockReset()});var Pe=async()=>{let e={json:()=>Promise.resolve(),status:200,ok:!0,headers:new Headers({"Content-Type":"application/json"})};return Promise.resolve(e)},G=async e=>{let{responseBody:t,status:n=200,headers:s={},delay:o}=e,r={json:()=>Promise.resolve(t),status:n,ok:n>=200&&n<=299,headers:new Headers({"Content-Type":"application/json",...s})};return o?new Promise(a=>setTimeout(()=>a(r),o)):Promise.resolve(r)},qe=e=>console.warn(`
|
|
2
|
+
${I.default.white.bold.bgRed("wrapito")} ${I.default.redBright.bold("cannot find any mock matching:")}
|
|
3
|
+
${I.default.greenBright(`URL: ${e.url}`)}
|
|
4
|
+
${I.default.greenBright(`METHOD: ${e.method?.toLowerCase()}`)}
|
|
5
|
+
${I.default.greenBright(`REQUEST BODY: ${e._bodyInit}`)}
|
|
6
|
+
`),V=async(e,t,n)=>{let s=e.find($(t));if(!s)return n&&qe(t),Pe();let{multipleResponses:o}=s;if(!o)return G(s);let r=o.find(a=>!a.hasBeenReturned);if(!r){n&&We(s);return}return r.hasBeenReturned=!0,G(r)},Q=(e=[],t=!1)=>{global.window.fetch.mockImplementation((s,o)=>{if(typeof s=="string"){let a=new Request(s,o);return V(e,a,t)}return V(e,s,t)})},We=e=>{let t=`\u{1F32F} Wrapito: Missing response in the multipleResponses array for path ${e.path} and method ${e.method}.`,n=I.default.greenBright(t);console.warn(n)};var S,y=e=>{S={...S,...e}},R=()=>({...S});beforeEach(()=>{global.fetch=P()});afterEach(()=>{global.fetch.mockReset()});var ve=e=>(y({Component:e,responses:[],props:{},path:"",hasPath:!1,interactionConfig:void 0,debug:process.env.npm_config_debugRequests==="true"}),b()),b=()=>{let e=Se();return{withProps:He,withNetwork:je,withInteraction:Be,atPath:Ne,debugRequests:$e,mount:Le,...e}},Ae=e=>{let t=R(),n=[...t.responses,...e];y({...t,responses:n})},Ce=(e,t)=>(t({addResponses:Ae},e),b()),De=(e,t)=>{let{extend:n}=d(),s=n[t];return{...e,[t]:(...o)=>Ce(o,s)}},Se=()=>{let{extend:e}=d();return Object.keys(e).reduce(De,{})},He=e=>{let t=R();return y({...t,props:e}),b()},Be=e=>{let t=R();return y({...t,interactionConfig:e}),b()},je=(e=[])=>{let t=R(),n=Array.isArray(e)?e:[e];return y({...t,responses:[...t.responses,...n]}),b()},Ne=(e,t)=>{let n=R();return y({...n,historyState:t,path:e,hasPath:!0}),b()},$e=()=>{let e=R();return y({...e,debug:!0}),b()},Le=()=>{let{portal:e,portals:t,changeRoute:n,history:s,mount:o,interaction:r}=d(),{Component:a,props:l,responses:i,path:u,hasPath:p,debug:m,historyState:c,interactionConfig:g}=R(),h=a;e&&Y(e),t&&Fe(t),p&&s&&(console.warn("wrapito WARNING: history is DEPRECATED. Pass a changeRoute function to the config instead."),console.warn("Read about changeRoute in: https://github.com/mercadona/wrapito#changeRoute"),s.push(u,c)),p&&!s&&n(u),Q(i,m);let f=o(J.createElement(h,{...l}));if(r){let k=r.setup?r.setup(r.userLib,g):r.userLib;return{...f,user:k}}return f},Y=e=>{if(document.getElementById(e))return;let t=document.createElement("div");t.setAttribute("id",e),t.setAttribute("data-testid",e),document.body.appendChild(t)},Fe=e=>{e.forEach(t=>{Y(t)})};var z=require("jest-diff"),H=(e,t)=>{let n=t?.host?`\u{1F32F} Wrapito: ${t?.host}${e} ain't got called`:`\u{1F32F} Wrapito: ${e} ain't got called`;return{pass:!1,message:()=>n}},K=(e,t,n)=>({pass:!1,message:()=>`\u{1F32F} Wrapito: ${e} is called ${n} times, you expected ${t} times`}),X=(e,t)=>({pass:!1,message:()=>`\u{1F32F} Wrapito: Fetch method does not match, expected ${e} received ${t??"none"}`}),Z=(e,t)=>{let n=t.map(s=>(0,z.diff)(e,s)).join(`
|
|
7
7
|
|
|
8
8
|
`);return{pass:!1,message:()=>`\u{1F32F} Wrapito: Fetch body does not match.
|
|
9
|
-
${
|
|
9
|
+
${n}`}},ee=(e,t)=>{let n=t.find(s=>e!==s);return{pass:!1,message:()=>`\u{1F32F} Wrapito: Host request does not match, expected ${e} received ${n}`}},te=()=>({pass:!1,message:()=>"\u{1F32F} Wrapito: Unable to find body."}),B=()=>({pass:!0,message:()=>"Test passing"}),ne=(e,t)=>{let n=t?.host?`\u{1F32F} Wrapito: ${t.host}${e} is called`:`\u{1F32F} Wrapito: ${e} is called`;return{pass:!0,message:()=>n}};var se=T(require("deep-equal"),1);var oe=()=>{let e=d().defaultHost;return e?.includes("http")?e:"https://default.com"},_e=(e="",t,n)=>t.includes(n)?t:e+t,q=e=>e instanceof Request,Ge=e=>q(e)?e.url:e,W=(e,t={method:"GET"})=>fetch.mock.calls.filter(([s])=>{let o=Ge(s),r=oe(),a=new URL(o,r),l=_e(t?.host,e,r),i=t?.host||r,u=new URL(l,i),p=a.pathname===u.pathname,m=a.search===u.search,c=a.host===u.host;return u.search?p&&m:t?.host?p&&c:p}),re=e=>e.flat(1).filter(q).map(t=>t.method),ae=e=>e.flat(1).filter(q).map(t=>t._bodyInit?JSON.parse(t._bodyInit):{}),ie=e=>e.flat(1).filter(q).map(t=>new URL(t.url,oe()).hostname),ce=(e,t)=>e&&!t.includes(e),pe=(e,t)=>t.map(s=>(0,se.default)(e,s)).every(s=>s===!1),ue=(e,t)=>t.every(s=>s!==e),le=e=>e.length===0;var Ve=(e,t)=>{let n=W(e);if(le(n))return H(e);let s=re(n),o=t?.method;if(ce(o,s))return X(o,s);let r=ae(n),a=t?.body;if(!a)return te();if(pe(a,r))return Z(a,r);let l=ie(n),i=t?.host;return i&&ue(i,l)?ee(i,l):B()},Qe=(e,t={method:"GET"})=>W(e,t).length?ne(e,t):H(e,t),Je=(e,t,n={method:"GET"})=>{let s=W(e,n);return s.length!==t?K(e,t,s.length):B()},Ye={toHaveBeenFetched:Qe,toHaveBeenFetchedWith:Ve,toHaveBeenFetchedTimes:Je};0&&(module.exports={assertions,configure,getConfig,matchers,wrap});
|
package/dist/index.mjs
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import*as _ from"react";import
|
|
2
|
-
${
|
|
3
|
-
${
|
|
4
|
-
${
|
|
5
|
-
${
|
|
6
|
-
`),
|
|
1
|
+
import*as _ from"react";import x from"chalk";import S from"object-hash";import{render as ae}from"@testing-library/react";var W={defaultHost:"",extend:{},mount:ae,changeRoute:e=>window.history.replaceState(null,"",e)};function Be(e){W={...W,...e}}var f=()=>({...W});var H=e=>t=>{let{method:n="GET",path:s,host:o=f().defaultHost,requestBody:r=void 0,catchParams:a}=t,l=o+s,i=!f().handleQueryParams||a,u=S({url:i?l:l.split("?")[0],method:n.toUpperCase(),requestBody:r}),p;return"_bodyInit"in e&&e._bodyInit!==void 0&&(p=JSON.parse(e._bodyInit)),S({url:i?e.url:e.url.split("?")[0],method:e.method,requestBody:p})===u};function O(e,t){if(!e)throw new Error(t)}function b(e,t){return typeof t===e}function ie(e){return e instanceof Promise}function v(e,t,n){Object.defineProperty(e,t,n)}function w(e,t,n){Object.defineProperty(e,t,{value:n})}var M=Symbol.for("tinyspy:spy"),ce=new Set,pe=e=>{e.called=!1,e.callCount=0,e.calls=[],e.results=[],e.next=[]},ue=e=>(v(e,M,{value:{reset:()=>pe(e[M])}}),e[M]),T=e=>e[M]||ue(e);function le(e){O(b("function",e)||b("undefined",e),"cannot spy on a non-function value");let t=function(...s){let o=T(t);o.called=!0,o.callCount++,o.calls.push(s);let r=o.next.shift();if(r){o.results.push(r);let[u,p]=r;if(u==="ok")return p;throw p}let a,l="ok";if(o.impl)try{new.target?a=Reflect.construct(o.impl,s,new.target):a=o.impl.apply(this,s),l="ok"}catch(u){throw a=u,l="error",o.results.push([l,u]),u}let i=[l,a];if(ie(a)){let u=a.then(p=>i[1]=p).catch(p=>{throw i[0]="error",i[1]=p,p});Object.assign(u,a),a=u}return o.results.push(i),a};w(t,"_isMockFunction",!0),w(t,"length",e?e.length:0),w(t,"name",e&&e.name||"spy");let n=T(t);return n.reset(),n.impl=e,t}var B=(e,t)=>Object.getOwnPropertyDescriptor(e,t),j=(e,t)=>{t!=null&&typeof t=="function"&&t.prototype!=null&&Object.setPrototypeOf(e.prototype,t.prototype)};function N(e,t,n){O(!b("undefined",e),"spyOn could not find an object to spy upon"),O(b("object",e)||b("function",e),"cannot spyOn on a primitive value");let[s,o]=(()=>{if(!b("object",t))return[t,"value"];if("getter"in t&&"setter"in t)throw new Error("cannot spy on both getter and setter");if("getter"in t)return[t.getter,"get"];if("setter"in t)return[t.setter,"set"];throw new Error("specify getter or setter to spy on")})(),r=B(e,s),a=Object.getPrototypeOf(e),l=a&&B(a,s),i=r||l;O(i||s in e,`${String(s)} does not exist`);let u=!1;o==="value"&&i&&!i.value&&i.get&&(o="get",u=!0,n=i.get());let p;i?p=i[o]:o!=="value"?p=()=>e[s]:p=e[s],n||(n=p);let m=le(n);o==="value"&&j(m,p);let c=h=>{let{value:k,...q}=i||{configurable:!0,writable:!0};o!=="value"&&delete q.writable,q[o]=h,v(e,s,q)},g=()=>i?v(e,s,i):c(p),d=m[M];return w(d,"restore",g),w(d,"getOriginal",()=>u?p():p),w(d,"willCall",h=>(d.impl=h,m)),c(u?()=>(j(m,n),m):m),ce.add(m),m}var de=new Set,he=0;function fe(e){let t=e,n,s=[],o=[],r=T(e),a={get calls(){return r.calls},get instances(){return s},get invocationCallOrder(){return o},get results(){return r.results.map(([c,g])=>({type:c==="error"?"throw":"return",value:g}))},get lastCall(){return r.calls[r.calls.length-1]}},l=[],i=!1;function u(...c){return s.push(this),o.push(++he),(i?n:l.shift()||n||r.getOriginal()||(()=>{})).apply(this,c)}let p=t.name;t.getMockName=()=>p||"vi.fn()",t.mockName=c=>(p=c,t),t.mockClear=()=>(r.reset(),s=[],o=[],t),t.mockReset=()=>(t.mockClear(),n=()=>{},l=[],t),t.mockRestore=()=>(t.mockReset(),r.restore(),n=void 0,t),t.getMockImplementation=()=>n,t.mockImplementation=c=>(n=c,r.willCall(u),t),t.mockImplementationOnce=c=>(l.push(c),t);function m(c,g){let d=n;n=c,r.willCall(u),i=!0;let h=()=>{n=d,i=!1},k=g();return k instanceof Promise?k.then(()=>(h(),t)):(h(),t)}return t.withImplementation=m,t.mockReturnThis=()=>t.mockImplementation(function(){return this}),t.mockReturnValue=c=>t.mockImplementation(()=>c),t.mockReturnValueOnce=c=>t.mockImplementationOnce(()=>c),t.mockResolvedValue=c=>t.mockImplementation(()=>Promise.resolve(c)),t.mockResolvedValueOnce=c=>t.mockImplementationOnce(()=>Promise.resolve(c)),t.mockRejectedValue=c=>t.mockImplementation(()=>Promise.reject(c)),t.mockRejectedValueOnce=c=>t.mockImplementationOnce(()=>Promise.reject(c)),Object.defineProperty(t,"mock",{get:()=>a}),r.willCall(u),de.add(t),t}var E=e=>fe(N({spy:e||(()=>{})},"spy"));beforeEach(()=>{global.window.fetch=E()});afterEach(()=>{global.window.fetch.mockReset()});var ge=async()=>{let e={json:()=>Promise.resolve(),status:200,ok:!0,headers:new Headers({"Content-Type":"application/json"})};return Promise.resolve(e)},$=async e=>{let{responseBody:t,status:n=200,headers:s={},delay:o}=e,r={json:()=>Promise.resolve(t),status:n,ok:n>=200&&n<=299,headers:new Headers({"Content-Type":"application/json",...s})};return o?new Promise(a=>setTimeout(()=>a(r),o)):Promise.resolve(r)},ye=e=>console.warn(`
|
|
2
|
+
${x.white.bold.bgRed("wrapito")} ${x.redBright.bold("cannot find any mock matching:")}
|
|
3
|
+
${x.greenBright(`URL: ${e.url}`)}
|
|
4
|
+
${x.greenBright(`METHOD: ${e.method?.toLowerCase()}`)}
|
|
5
|
+
${x.greenBright(`REQUEST BODY: ${e._bodyInit}`)}
|
|
6
|
+
`),L=async(e,t,n)=>{let s=e.find(H(t));if(!s)return n&&ye(t),ge();let{multipleResponses:o}=s;if(!o)return $(s);let r=o.find(a=>!a.hasBeenReturned);if(!r){n&&Re(s);return}return r.hasBeenReturned=!0,$(r)},F=(e=[],t=!1)=>{global.window.fetch.mockImplementation((s,o)=>{if(typeof s=="string"){let a=new Request(s,o);return L(e,a,t)}return L(e,s,t)})},Re=e=>{let t=`\u{1F32F} Wrapito: Missing response in the multipleResponses array for path ${e.path} and method ${e.method}.`,n=x.greenBright(t);console.warn(n)};var A,y=e=>{A={...A,...e}},R=()=>({...A});beforeEach(()=>{global.fetch=E()});afterEach(()=>{global.fetch.mockReset()});var Ze=e=>(y({Component:e,responses:[],props:{},path:"",hasPath:!1,interactionConfig:void 0,debug:process.env.npm_config_debugRequests==="true"}),I()),I=()=>{let e=xe();return{withProps:ke,withNetwork:Oe,withInteraction:Me,atPath:Te,debugRequests:Ee,mount:Ue,...e}},Ie=e=>{let t=R(),n=[...t.responses,...e];y({...t,responses:n})},be=(e,t)=>(t({addResponses:Ie},e),I()),we=(e,t)=>{let{extend:n}=f(),s=n[t];return{...e,[t]:(...o)=>be(o,s)}},xe=()=>{let{extend:e}=f();return Object.keys(e).reduce(we,{})},ke=e=>{let t=R();return y({...t,props:e}),I()},Me=e=>{let t=R();return y({...t,interactionConfig:e}),I()},Oe=(e=[])=>{let t=R(),n=Array.isArray(e)?e:[e];return y({...t,responses:[...t.responses,...n]}),I()},Te=(e,t)=>{let n=R();return y({...n,historyState:t,path:e,hasPath:!0}),I()},Ee=()=>{let e=R();return y({...e,debug:!0}),I()},Ue=()=>{let{portal:e,portals:t,changeRoute:n,history:s,mount:o,interaction:r}=f(),{Component:a,props:l,responses:i,path:u,hasPath:p,debug:m,historyState:c,interactionConfig:g}=R(),d=a;e&&G(e),t&&Pe(t),p&&s&&(console.warn("wrapito WARNING: history is DEPRECATED. Pass a changeRoute function to the config instead."),console.warn("Read about changeRoute in: https://github.com/mercadona/wrapito#changeRoute"),s.push(u,c)),p&&!s&&n(u),F(i,m);let h=o(_.createElement(d,{...l}));if(r){let k=r.setup?r.setup(r.userLib,g):r.userLib;return{...h,user:k}}return h},G=e=>{if(document.getElementById(e))return;let t=document.createElement("div");t.setAttribute("id",e),t.setAttribute("data-testid",e),document.body.appendChild(t)},Pe=e=>{e.forEach(t=>{G(t)})};import{diff as qe}from"jest-diff";var C=(e,t)=>{let n=t?.host?`\u{1F32F} Wrapito: ${t?.host}${e} ain't got called`:`\u{1F32F} Wrapito: ${e} ain't got called`;return{pass:!1,message:()=>n}},V=(e,t,n)=>({pass:!1,message:()=>`\u{1F32F} Wrapito: ${e} is called ${n} times, you expected ${t} times`}),Q=(e,t)=>({pass:!1,message:()=>`\u{1F32F} Wrapito: Fetch method does not match, expected ${e} received ${t??"none"}`}),J=(e,t)=>{let n=t.map(s=>qe(e,s)).join(`
|
|
7
7
|
|
|
8
8
|
`);return{pass:!1,message:()=>`\u{1F32F} Wrapito: Fetch body does not match.
|
|
9
|
-
${
|
|
9
|
+
${n}`}},Y=(e,t)=>{let n=t.find(s=>e!==s);return{pass:!1,message:()=>`\u{1F32F} Wrapito: Host request does not match, expected ${e} received ${n}`}},z=()=>({pass:!1,message:()=>"\u{1F32F} Wrapito: Unable to find body."}),D=()=>({pass:!0,message:()=>"Test passing"}),K=(e,t)=>{let n=t?.host?`\u{1F32F} Wrapito: ${t.host}${e} is called`:`\u{1F32F} Wrapito: ${e} is called`;return{pass:!0,message:()=>n}};import We from"deep-equal";var X=()=>{let e=f().defaultHost;return e?.includes("http")?e:"https://default.com"},ve=(e="",t,n)=>t.includes(n)?t:e+t,U=e=>e instanceof Request,Ae=e=>U(e)?e.url:e,P=(e,t={method:"GET"})=>fetch.mock.calls.filter(([s])=>{let o=Ae(s),r=X(),a=new URL(o,r),l=ve(t?.host,e,r),i=t?.host||r,u=new URL(l,i),p=a.pathname===u.pathname,m=a.search===u.search,c=a.host===u.host;return u.search?p&&m:t?.host?p&&c:p}),Z=e=>e.flat(1).filter(U).map(t=>t.method),ee=e=>e.flat(1).filter(U).map(t=>t._bodyInit?JSON.parse(t._bodyInit):{}),te=e=>e.flat(1).filter(U).map(t=>new URL(t.url,X()).hostname),ne=(e,t)=>e&&!t.includes(e),se=(e,t)=>t.map(s=>We(e,s)).every(s=>s===!1),oe=(e,t)=>t.every(s=>s!==e),re=e=>e.length===0;var Ce=(e,t)=>{let n=P(e);if(re(n))return C(e);let s=Z(n),o=t?.method;if(ne(o,s))return Q(o,s);let r=ee(n),a=t?.body;if(!a)return z();if(se(a,r))return J(a,r);let l=te(n),i=t?.host;return i&&oe(i,l)?Y(i,l):D()},De=(e,t={method:"GET"})=>P(e,t).length?K(e,t):C(e,t),Se=(e,t,n={method:"GET"})=>{let s=P(e,n);return s.length!==t?V(e,t,s.length):D()},ct={toHaveBeenFetched:De,toHaveBeenFetchedWith:Ce,toHaveBeenFetchedTimes:Se};export{ct as assertions,Be as configure,f as getConfig,ct as matchers,Ze as wrap};
|