Skip to content

Commit

Permalink
Merge pull request #860 from recurly/put
Browse files Browse the repository at this point in the history
Adds PUT support to Request
  • Loading branch information
douglasmiller authored Nov 8, 2023
2 parents a88e7c8 + d4b99fc commit 5660039
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 1 deletion.
2 changes: 1 addition & 1 deletion lib/recurly/request.js
Original file line number Diff line number Diff line change
Expand Up @@ -303,7 +303,7 @@ export class Request {

// XDR requests will abort if too many are sent simultaneously
setTimeout(() => {
if (method === 'post') {
if (method === 'post' || method === 'put') {
// XDR cannot set Content-type
if (req.setRequestHeader) {
req.setRequestHeader('Content-type', 'application/x-www-form-urlencoded');
Expand Down
12 changes: 12 additions & 0 deletions test/unit/request.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,18 @@ describe('Request', () => {
});
});

describe('when performing a PUT request', () => {
beforeEach(function (done) {
const proceed = () => done();
this.request.request({ method: 'put', route: '/test', data: this.example }).done(proceed, proceed);
});

it('sends properly-encoded data in the request body', function () {
assert(this.XHR.prototype.open.calledWithExactly('put', `${this.recurly.config.api}/test`));
assert(this.XHR.prototype.send.calledWithExactly(this.exampleEncoded()));
});
});

describe('when performing a GET request', () => {
beforeEach(function (done) {
const proceed = () => done();
Expand Down

0 comments on commit 5660039

Please sign in to comment.