5

我正在测试我的 GraphQL API,但我想稍微清理一下。值得注意的是,我正在使用chai-http网络请求。这是我目前正在做的事情(有效):

let createUser = (()=> {
  return new Promise((resolve, reject) => {
    chai.request(server)
      .post('/api/graphql/')
      .set('content-type', 'application/json')
      .send({ 'query' : 
        'mutation users { \
          user : addUser(inputs: { \
            firstName: \"Test\", \
            lastName: \"User\", \
            email: \"test@test.com\", \
          }) { \
            id, \
            firstName \
          } \
        }'
      })
      .end((err, res) => {
        if (err) { reject(err) }
        let data = res.body.data;
        let user = data.user;
        resolve(user);
      })
  });
});

但是,我想清理一下并执行以下操作:

let createUser = (() => {
  let newUser = {
    firstName: 'Test',
    lastName: 'User',
    email: 'test@test.com'
  };

  return new Promise((resolve, reject) => {
    chai.request(server)
      .post('/api/graphql/')
      .set('content-type', 'application/json')
      .send({ 'query' : 
        'mutation users { \
          user : addUser(inputs: ' + JSON.stringify(newUser) + ') { \
            id, \
            firstName \
          } \
        }'
      })
      .end((err, res) => {
        if (err) { reject(err) }
        let data = res.body.data;
        let user = data.user;
        resolve(user);
      })
  });
});

但是,这种放置对象输入的样式不起作用并返回错误的请求错误。以下是返回的错误对象的部分内容:

在此处输入图像描述

任何想法为什么这不起作用?提前致谢!

4

1 回答 1

6

看起来您的 JSON 输入有问题。可能是您的换行符和引号的某种组合在服务器上无法正确解析。

但是,我仍然不建议像在 GraphQL 查询中那样内联变量。你应该这样做:

let createUser = (() => {
  let newUser = {
    firstName: 'Test',
    lastName: 'User',
    email: 'test@test.com'
  };

  return new Promise((resolve, reject) => {
    chai.request(server)
      .post('/api/graphql/')
      .set('content-type', 'application/json')
      .send({
        'query' : 'mutation users ($input: CreateUserInput!) { \
          user : addUser(inputs: $input) { \
            id, \
            firstName \
          } \
        }',
        'variables' : {
           'input': newUser
         }
      })
      .end((err, res) => {
        if (err) { reject(err) }
        let data = res.body.data;
        let user = data.user;
        resolve(user);
      })
  });
});

您可以在此处查看另一个简单示例,了解如何在 Scaphold 上执行突变以创建用户queryvariables拆分。

希望这可以帮助!

于 2017-05-12T18:15:36.850 回答