Использование apollo-link на клиенте и PubSub из apollo-server-express на сервере.Получается странный результат в тесте мокко при общении с API GraphQL:
мокко:
import { execute, makePromise } from 'apollo-link';
const uri = 'http://localhost:3001/graphql';
const link = new HttpLink({ uri, fetch });
const subscribe = (query, handlers) => {
const operation = {
query: gql`${query}`,
};
return execute(link, operation).subscribe(handlers);
};
const handlers = {
next: (data) => {
console.log(`received data: ${Date.now()}, ${JSON.stringify(data, null, 2)}`);
},
error: error => console.log(`received error ${error}`),
complete: () => console.log('complete'),
};
it('subscribe', async () => {
const query = `subscription {
info
}`;
subscribe(query, handlers);
});
Сервер:
try {
console.log('subscription =>| ', Date.now(), '|', line);
worker.pubsub.publish('infoTopic', { info: line });
} catch (e) {
console.error(e);
}
Вот что я вижу (из теста):
полученные данные: 1545013826838, {"errors": [{"message": "Невозможно вернуть значение NULL для пустого поля Subscription.info.", ...
(с сервера):
подписка => |1545013826887 |глубина информации 1 seldepth 1 ...
Подписчик получает на 826 838 , а издатель отправляет на 826 887
Чточерт возьми?