Sinon fakeServer не смогла имитировать POST: 'TypeError: Согласно RFC7230, раздел 3.2.4, значения заголовка должны быть строками.Получил объект - PullRequest
0 голосов
/ 21 февраля 2019

Метод GET работает нормально, но всегда возникают проблемы с POST.мой тестовый код

let server = sinon.createFakeServer();
server.respondImmediately = true;
server.respondWith(`api/v1.0/companies/${companyResponse.id}/orgchart`, [200,  {"Content-Type": "*/*"}, 'OK']);

, ниже приведен вызов ajax:

  ajax({
    type: "POST",
    url: '/my/api/endpoint',
    data: data,
    processData: false,
    contentType: false,
    complete: this.handleLoadingComplete,
    xhr: function(){
      let xhr = $.ajaxSettings.xhr() ;
      xhr.upload.onprogress = function(evt){
        updateProgress(evt.loaded, evt.total);
      } ;
      xhr.upload.onload = function(){ console.log('loading completed') } ;
      return xhr ;
    }        
  });

с использованием точно такого же тестового кода, когда я устанавливаю метод ajax в 'GET', он работает.Но с «POST» это всегда не удавалось.Это ответ, полученный complete из вышеупомянутого ajax POST:

`

{ readyState: 0,
      getResponseHeader: [Function: getResponseHeader],
      getAllResponseHeaders: [Function: getAllResponseHeaders],
      setRequestHeader: [Function: setRequestHeader],
      overrideMimeType: [Function: overrideMimeType],
      statusCode: [Function: statusCode],
      abort: [Function: abort],
      state: [Function: state],
      always: [Function: always],
      catch: [Function: catch],
      pipe: [Function: pipe],
      then: [Function: then],
      promise: [Function: promise],
      progress: [Function: add],
      done: [Function: add],
      fail: [Function: add],
      status: 0,
      statusText:
       'TypeError: By RFC7230, section 3.2.4, header values should be strings. Got object' }

` Я понятия не имею, в чем здесь ошибка, и я застрял на несколько часов ...Может ли кто-нибудь помочь?Буду очень признателен!

1 Ответ

0 голосов
/ 19 августа 2019

У меня та же проблема, и в моем случае это связано с тем, как axios устанавливает заголовки.Это не настоящее решение, но исправление проблемы с помощью закрепления sinon и принудительной установки более старой версии nise.Вот фрагмент кода package.json:

  ...
  "devSependencies": {
    ...
    "sinon": "^4.5.0",
    ...
  }
  ...
  "resolutions:" {
    "nise": "1.2.7"
  }
  ...
...