mirror of
https://github.com/wassname/talk.git
synced 2026-07-04 03:54:06 +08:00
100 lines
2.7 KiB
TypeScript
100 lines
2.7 KiB
TypeScript
import React from "react";
|
|
import TestRenderer, { ReactTestRenderer } from "react-test-renderer";
|
|
import { RecordProxy } from "relay-runtime";
|
|
import sinon from "sinon";
|
|
|
|
import { timeout } from "talk-common/utils";
|
|
import { TalkContext, TalkContextProvider } from "talk-framework/lib/bootstrap";
|
|
import { PostMessageService } from "talk-framework/lib/postMessage";
|
|
import { RestClient } from "talk-framework/lib/rest";
|
|
import { createInMemoryStorage } from "talk-framework/lib/storage";
|
|
import { createSinonStub } from "talk-framework/testHelpers";
|
|
import AppContainer from "talk-stream/containers/AppContainer";
|
|
|
|
import createEnvironment from "./createEnvironment";
|
|
import createFluentBundle from "./createFluentBundle";
|
|
import createNodeMock from "./createNodeMock";
|
|
import { assets, comments } from "./fixtures";
|
|
|
|
let testRenderer: ReactTestRenderer;
|
|
beforeEach(() => {
|
|
const commentStub = {
|
|
...comments[0],
|
|
};
|
|
|
|
const assetStub = {
|
|
...assets[0],
|
|
comments: {
|
|
pageInfo: {
|
|
hasNextPage: false,
|
|
},
|
|
edges: [
|
|
{
|
|
node: commentStub,
|
|
cursor: commentStub.createdAt,
|
|
},
|
|
],
|
|
},
|
|
};
|
|
|
|
const resolvers = {
|
|
Query: {
|
|
comment: createSinonStub(
|
|
s => s.throws(),
|
|
s => s.withArgs(undefined, { id: commentStub.id }).returns(commentStub)
|
|
),
|
|
asset: createSinonStub(
|
|
s => s.throws(),
|
|
s => s.withArgs(undefined, { id: assetStub.id }).returns(assetStub)
|
|
),
|
|
},
|
|
};
|
|
|
|
const environment = createEnvironment({
|
|
// Set this to true, to see graphql responses.
|
|
logNetwork: false,
|
|
resolvers,
|
|
initLocalState: (localRecord: RecordProxy) => {
|
|
localRecord.setValue(0, "authRevision");
|
|
localRecord.setValue(assetStub.id, "assetID");
|
|
localRecord.setValue(commentStub.id, "commentID");
|
|
},
|
|
});
|
|
|
|
const context: TalkContext = {
|
|
relayEnvironment: environment,
|
|
localeBundles: [createFluentBundle()],
|
|
localStorage: createInMemoryStorage(),
|
|
sessionStorage: createInMemoryStorage(),
|
|
rest: new RestClient("http://localhost/api"),
|
|
postMessage: new PostMessageService(),
|
|
};
|
|
|
|
testRenderer = TestRenderer.create(
|
|
<TalkContextProvider value={context}>
|
|
<AppContainer />
|
|
</TalkContextProvider>,
|
|
{ createNodeMock }
|
|
);
|
|
});
|
|
|
|
it("renders permalink view", async () => {
|
|
// Wait for loading.
|
|
await timeout();
|
|
expect(testRenderer.toJSON()).toMatchSnapshot();
|
|
});
|
|
|
|
it("show all comments", async () => {
|
|
const mockEvent = {
|
|
preventDefault: sinon.mock().once(),
|
|
};
|
|
testRenderer.root
|
|
.findByProps({
|
|
id: "talk-comments-permalinkView-showAllComments",
|
|
})
|
|
.props.onClick(mockEvent);
|
|
await timeout();
|
|
expect(testRenderer.toJSON()).toMatchSnapshot();
|
|
mockEvent.preventDefault.verify();
|
|
});
|