本文整理匯總了TypeScript中apollo-link.ApolloLink類的典型用法代碼示例。如果您正苦於以下問題:TypeScript ApolloLink類的具體用法?TypeScript ApolloLink怎麽用?TypeScript ApolloLink使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了ApolloLink類的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: it
it('does not update the cache on a mutation', () => {
let called = 0;
const inspector = new ApolloLink((operation, forward) => {
called++;
return forward(operation).map(result => {
called++;
return result;
});
});
const client = new ApolloClient({
link: inspector.concat(createMutationLink()),
cache: new InMemoryCache({ addTypename: false }),
});
return client
.query({ query })
.then(() =>
client.mutate({ mutation, variables, fetchPolicy: 'no-cache' }),
)
.then(() => {
return client.query({ query }).then(actualResult => {
expect(actualResult.data).toEqual(result);
});
});
});
示例2: it
it('will return null when an id that canât be found is provided', () => {
const client1 = new ApolloClient({
link: ApolloLink.empty(),
cache: new InMemoryCache(),
});
const client2 = new ApolloClient({
link: ApolloLink.empty(),
cache: new InMemoryCache().restore({
bar: { __typename: 'Foo', a: 1, b: 2, c: 3 },
}),
});
const client3 = new ApolloClient({
link: ApolloLink.empty(),
cache: new InMemoryCache().restore({
foo: { __typename: 'Foo', a: 1, b: 2, c: 3 },
}),
});
expect(
client1.readFragment({
id: 'foo',
fragment: gql`
fragment fooFragment on Foo {
a
b
c
}
`,
}),
).toBe(null);
expect(
client2.readFragment({
id: 'foo',
fragment: gql`
fragment fooFragment on Foo {
a
b
c
}
`,
}),
).toBe(null);
expect(
client3.readFragment({
id: 'foo',
fragment: gql`
fragment fooFragment on Foo {
a
b
c
}
`,
}),
).toEqual({ __typename: 'Foo', a: 1, b: 2, c: 3 });
});
示例3: it
it(`does not affect different queries`, () => {
const document: DocumentNode = gql`
query test1($x: String) {
test(x: $x)
}
`;
const variables1 = { x: 'Hello World' };
const variables2 = { x: 'Goodbye World' };
const request1: GraphQLRequest = {
query: document,
variables: variables1,
operationName: getOperationName(document),
};
const request2: GraphQLRequest = {
query: document,
variables: variables2,
operationName: getOperationName(document),
};
let called = 0;
const deduper = ApolloLink.from([
new DedupLink(),
new ApolloLink(() => {
called += 1;
return null;
}),
]);
execute(deduper, request1);
execute(deduper, request2);
expect(called).toBe(2);
});
示例4: createApolloClient
export default function createApolloClient() {
return new ApolloClient({
link: ApolloLink.from([restLink, middlewareLink, httpLink]),
cache: new InMemoryCache(),
connectToDevTools: devMode
});
}
示例5: constructor
constructor(
private apollo: Apollo,
private tokenService: TokenService,
private modalService: ModalService
) {
const uploadLink = createUploadLink({ uri: uri });
const authLink = createAuthLink(tokenService);
const errorLink = createErrorLink(modalService);
apollo.create({
link: ApolloLink.from([authLink, errorLink, uploadLink]),
cache: new InMemoryCache(),
queryDeduplication: true,
defaultOptions: {
mutate: {
errorPolicy: 'all'
},
query: {
errorPolicy: 'all'
},
watchQuery: {
errorPolicy: 'all'
}
}
});
}
示例6: InMemoryCache
() => {
const query = gql`
{
fie: foo @client {
bar
}
}
`;
const cache = new InMemoryCache();
const client = new ApolloClient({
cache,
link: ApolloLink.empty(),
});
cache.writeData({
data: {
foo: {
bar: 'yo',
__typename: 'Foo',
},
},
});
return client.query({ query }).then(({ data }) => {
expect({ ...data }).toMatchObject({
fie: { bar: 'yo', __typename: 'Foo' },
});
});
},
示例7: it
it('throws an error when more requests than results', done => {
const result = [{ data: {} }];
const batchHandler = jest.fn(op => Observable.of(result));
const link = ApolloLink.from([
new BatchLink({
batchInterval: 10,
batchMax: 2,
batchHandler,
}),
]);
[1, 2].forEach(x => {
execute(link, {
query,
}).subscribe({
next: data => {
done.fail('next should not be called');
},
error: terminatingCheck(done, error => {
expect(error).toBeDefined();
expect(error.result).toEqual(result);
}),
complete: () => {
done.fail('complete should not be called');
},
});
});
});
示例8: it
it('does a network request if fetchPolicy is cache-only then store is reset then fetchPolicy becomes not cache-only', done => {
let queryManager: QueryManager;
let observable: ObservableQuery<any>;
const testQuery = gql`
query {
author {
firstName
lastName
}
}
`;
const data = {
author: {
firstName: 'John',
lastName: 'Smith',
},
};
let timesFired = 0;
const link: ApolloLink = ApolloLink.from([
() => {
return new Observable(observer => {
timesFired += 1;
observer.next({ data });
observer.complete();
return;
});
},
]);
queryManager = createQueryManager({ link });
observable = queryManager.watchQuery({ query: testQuery });
subscribeAndCount(done, observable, (handleCount, result) => {
try {
if (handleCount === 1) {
expect(result.data).toEqual(data);
expect(timesFired).toBe(1);
setTimeout(() => {
observable.setOptions({ fetchPolicy: 'cache-only' });
queryManager.resetStore();
}, 0);
} else if (handleCount === 2) {
expect(result.data).toEqual({});
expect(timesFired).toBe(1);
setTimeout(() => {
observable.setOptions({ fetchPolicy: 'cache-first' });
}, 0);
} else if (handleCount === 3) {
expect(result.data).toEqual(data);
expect(timesFired).toBe(2);
done();
}
} catch (e) {
done.fail(e);
}
});
});