Skip to main content
Version: 1.2.0

NetSuite

You'll need to provide the following variables in your postman collection:

VariableDescriptionExample
API_VERSIONRepresents the version of the Alloy Unified API you intend to make calls to. API versions are dated and new versions are released quarterly (in March, June, September, and December).2023-12
connectionIdThe Id of the connection. Call the GET List Connections endpoint to find a connectionId.
apiKeyYour API key. Never share this with anyone.


JSON
{
"info": {
"_postman_id": "696b5e01-a914-4a6e-8295-c3764ad6600d",
"name": "Netsuite UAPI",
"schema": "https://schema.getpostman.com/json/collection/v2.1.0/collection.json",
"_exporter_id": "19112139",
"_collection_link": "https://planetary-crater-495600.postman.co/workspace/Alloy-One-New~68c3616b-3ff3-473b-ba08-af2e97a835e5/collection/19112139-696b5e01-a914-4a6e-8295-c3764ad6600d?action=share&source=collection_link&creator=19112139"
},
"item": [
{
"name": "01 Setup",
"item": [
{
"name": "Setup UAPI Data",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;\r",
"\r",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");\r",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;\r",
" \r",
"if (contentTypeHeaderExists) {\r",
" tests[\"Content-Type is application/json\"] = \r",
" responseHeaders[\"Content-Type\"].has(\"application/json\");\r",
"}\r",
"\r",
"\r",
"\r",
"var jsonData = pm.response.json();\r",
"console.log(jsonData);\r",
"let nsCredentialId = jsonData.nsCredentialId;\r",
"postman.setEnvironmentVariable(\"nsCredentialId\", nsCredentialId);\r",
"postman.setEnvironmentVariable(\"URL\", pm.environment.get(\"embedded_api_base_url\"));"
],
"type": "text/javascript",
"packages": {}
}
}
],
"request": {
"auth": {
"type": "noauth"
},
"method": "GET",
"header": [
{
"key": "X-Alloy-Auth",
"value": "1234567890abcdefghijklmnopqrstuvwxyz",
"type": "text"
}
],
"url": {
"raw": "{{api_base_url}}/api/testHelpers/setupUapi/NETSUITE",
"host": ["{{api_base_url}}"],
"path": ["api", "testHelpers", "setupUapi", "NETSUITE"]
}
},
"response": []
}
]
},
{
"name": "02 Create then Retrieve",
"item": [
{
"name": "Create Account",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] account is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData.account).to.not.be.null;",
" pm.expect(jsonData.account).to.have.property('remoteId');",
" pm.expect(jsonData.account).to.have.property('accountName');",
" pm.expect(jsonData.account).to.have.property('accountDescription');",
" pm.expect(jsonData.account).to.have.property('classification');",
" pm.expect(jsonData.account).to.have.property('accountType');",
" pm.expect(jsonData.account).to.have.property('accountStatus');",
" pm.expect(jsonData.account).to.have.property('currentBalance');",
" pm.expect(jsonData.account).to.have.property('currency');",
" pm.expect(jsonData.account).to.have.property('accountNumber');",
" pm.expect(jsonData.account).to.have.property('parentAccountId');",
" pm.expect(jsonData.account).to.have.property('companyId');",
" pm.expect(jsonData.account).to.have.property('id');",
" pm.expect(jsonData.account).to.have.property('remoteDeleted');",
" pm.expect(jsonData.account).to.have.property('createdAt');",
" pm.expect(jsonData.account).to.have.property('updatedAt');",
" pm.expect(jsonData.account.classification).to.equal('ASSET');",
" pm.expect(jsonData.account.accountType).to.equal('OTHER_ASSET');",
" pm.expect(jsonData.account.currency).to.equal('USD');",
"});",
"",
"var jsonData = pm.response.json();",
"let accountId = jsonData.account.id;",
"postman.setEnvironmentVariable(\"accountId\", accountId);"
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "POST",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"accountName\": \"FrancisChild+{{$randomUUID}}\",\n \"accountType\": \"OTHER_ASSET\",\n \"currency\": \"USD\"\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/accounts?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": ["{{API_VERSION}}", "one", "accounting", "accounts"],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Retrieve Account",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] account is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" console.log(jsonData);",
" pm.expect(jsonData.account).to.not.be.null;",
" pm.expect(jsonData.account).to.have.property('remoteId');",
" pm.expect(jsonData.account).to.have.property('accountName');",
" pm.expect(jsonData.account).to.have.property('accountDescription');",
" pm.expect(jsonData.account).to.have.property('classification');",
" pm.expect(jsonData.account).to.have.property('accountType');",
" pm.expect(jsonData.account).to.have.property('accountStatus');",
" pm.expect(jsonData.account).to.have.property('currentBalance');",
" pm.expect(jsonData.account).to.have.property('currency');",
" pm.expect(jsonData.account).to.have.property('accountNumber');",
" pm.expect(jsonData.account).to.have.property('parentAccountId');",
" pm.expect(jsonData.account).to.have.property('companyId');",
" pm.expect(jsonData.account).to.have.property('id');",
" pm.expect(jsonData.account).to.have.property('remoteDeleted');",
" pm.expect(jsonData.account).to.have.property('createdAt');",
" pm.expect(jsonData.account).to.have.property('updatedAt');",
"});"
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
},
"disableBodyPruning": true
},
"request": {
"method": "GET",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/accounts/{{accountId}}?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"accounts",
"{{accountId}}"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Create Customer",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] customer is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('customer');",
" pm.expect(jsonData.customer).to.not.be.null;",
" pm.expect(jsonData.customer).to.have.property('remoteId');",
" pm.expect(jsonData.customer).to.have.property('customerName');",
" pm.expect(jsonData.customer).to.have.property('email');",
" pm.expect(jsonData.customer).to.have.property('taxNumber');",
" pm.expect(jsonData.customer).to.have.property('customerStatus');",
" pm.expect(jsonData.customer).to.have.property('currency');",
" pm.expect(jsonData.customer).to.have.property('companyId');",
" pm.expect(jsonData.customer).to.have.property('addresses');",
" pm.expect(jsonData.customer.addresses).to.be.an('array').that.is.not.empty;",
" pm.expect(jsonData.customer.addresses[0]).to.have.property('addressType');",
" pm.expect(jsonData.customer.addresses[0]).to.have.property('street1');",
" pm.expect(jsonData.customer).to.have.property('phoneNumbers');",
" pm.expect(jsonData.customer.phoneNumbers).to.be.an('array').that.is.not.empty;",
" pm.expect(jsonData.customer.phoneNumbers[0]).to.have.property('phoneNumberType');",
" pm.expect(jsonData.customer.phoneNumbers[0]).to.have.property('phoneNumber');",
" pm.expect(jsonData.customer).to.have.property('addresses');",
" pm.expect(jsonData.customer).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.customer).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.customer).to.have.property('remoteDeleted');",
" pm.expect(jsonData.customer).to.have.property('createdAt');",
" pm.expect(jsonData.customer).to.have.property('updatedAt');",
" pm.expect(jsonData.customer).to.have.property('id');",
" pm.expect(jsonData.customer.addresses[0].addressType).to.equal('BILLING');",
" pm.expect(jsonData.customer.addresses[0].street1).to.equal('Beverly Hills');",
" pm.expect(jsonData.customer.addresses[0].zipCode).to.equal('90210');",
" pm.expect(jsonData.customer.addresses[0].country).to.equal('US');",
" pm.expect(jsonData.customer.phoneNumbers[0].phoneNumber).to.equal('09173210215');",
" pm.expect(jsonData.customer.phoneNumbers[0].phoneNumberType).to.equal('MOBILE');",
"});",
"",
"var jsonData = pm.response.json();",
"let customerId = jsonData.customer.id;",
"postman.setEnvironmentVariable(\"customerId\", customerId);",
"let customerAddressRemoteId = jsonData.customer.addresses[0].remoteId;",
"postman.setEnvironmentVariable(\"customerAddressRemoteId\", customerAddressRemoteId);"
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "POST",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"customerName\": \"Alloy+{{$randomUUID}}\",\n \"addresses\": [\n { \n \"addressType\": \"BILLING\",\n \"street1\": \"Beverly Hills\",\n \"zipCode\": \"90210\",\n \"country\": \"US\"\n }\n ],\n \"phoneNumbers\": [\n {\n \"phoneNumberType\": \"MOBILE\",\n \"phoneNumber\": \"09173210215\"\n }\n ]\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/customers?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": ["{{API_VERSION}}", "one", "accounting", "customers"],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Retrieve Customer",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"customer is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('customer');",
" pm.expect(jsonData.customer).to.not.be.null;",
" pm.expect(jsonData.customer).to.have.property('remoteId');",
" pm.expect(jsonData.customer).to.have.property('customerName');",
" pm.expect(jsonData.customer).to.have.property('email');",
" pm.expect(jsonData.customer).to.have.property('taxNumber');",
" pm.expect(jsonData.customer).to.have.property('customerStatus');",
" pm.expect(jsonData.customer).to.have.property('currency');",
" pm.expect(jsonData.customer).to.have.property('companyId');",
" pm.expect(jsonData.customer).to.have.property('addresses');",
" pm.expect(jsonData.customer).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.customer).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.customer).to.have.property('remoteDeleted');",
" pm.expect(jsonData.customer).to.have.property('createdAt');",
" pm.expect(jsonData.customer).to.have.property('updatedAt');",
" pm.expect(jsonData.customer).to.have.property('id');",
"});"
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
},
"disableBodyPruning": true
},
"request": {
"method": "GET",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/customers/{{customerId}}?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"customers",
"{{customerId}}"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Create Vendor",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"vendor is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('vendor');",
" pm.expect(jsonData.vendor).to.not.be.null;",
" pm.expect(jsonData.vendor).to.have.property('remoteId');",
" pm.expect(jsonData.vendor).to.have.property('vendorName');",
" pm.expect(jsonData.vendor).to.have.property('email');",
" pm.expect(jsonData.vendor).to.have.property('taxNumber');",
" pm.expect(jsonData.vendor).to.have.property('vendorStatus');",
" pm.expect(jsonData.vendor).to.have.property('currency');",
" pm.expect(jsonData.vendor).to.have.property('companyId');",
" pm.expect(jsonData.vendor).to.have.property('addresses');",
" pm.expect(jsonData.vendor.addresses).to.be.an('array').that.is.not.empty;",
" pm.expect(jsonData.vendor).to.have.property('phoneNumbers');",
" pm.expect(jsonData.vendor).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.vendor).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.vendor).to.have.property('remoteDeleted');",
" pm.expect(jsonData.vendor).to.have.property('createdAt');",
" pm.expect(jsonData.vendor).to.have.property('updatedAt');",
" pm.expect(jsonData.vendor).to.have.property('id');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('addressType');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('street1');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('street2');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('city');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('state');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('country');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('countrySubdivision');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('country');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('zipCode');",
" pm.expect(jsonData.vendor.addresses[0].street1).to.equal('Avenue of the Americas');",
" pm.expect(jsonData.vendor.addresses[0].zipCode).to.equal('90210');",
"",
"});",
"",
"var jsonData = pm.response.json();",
"let vendorId = jsonData.vendor.id;",
"postman.setEnvironmentVariable(\"vendorId\", vendorId);",
"let vendorAddressRemoteId = jsonData.vendor.addresses[0].remoteId;",
"postman.setEnvironmentVariable(\"vendorAddressRemoteId\", vendorAddressRemoteId);"
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "POST",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"vendorName\": \"Alloy+Vendor+{{$randomUUID}}\",\n \"vendorStatus\": \"ACTIVE\",\n \"addresses\": [\n { \n \"addressType\": \"BILLING\",\n \"street1\": \"Avenue of the Americas\",\n \"zipCode\": \"90210\",\n \"country\": \"US\"\n }\n ],\n \"phoneNumbers\": [\n {\n \"phoneNumberType\": \"MOBILE\",\n \"phoneNumber\": \"09173210215\"\n }\n ]\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/vendors?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": ["{{API_VERSION}}", "one", "accounting", "vendors"],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Retrieve Vendor",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] vendor is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('vendor');",
" pm.expect(jsonData.vendor).to.not.be.null;",
" pm.expect(jsonData.vendor).to.have.property('remoteId');",
" pm.expect(jsonData.vendor).to.have.property('vendorName');",
" pm.expect(jsonData.vendor).to.have.property('email');",
" pm.expect(jsonData.vendor).to.have.property('taxNumber');",
" pm.expect(jsonData.vendor).to.have.property('vendorStatus');",
" pm.expect(jsonData.vendor).to.have.property('currency');",
" pm.expect(jsonData.vendor).to.have.property('companyId');",
" pm.expect(jsonData.vendor).to.have.property('addresses');",
" pm.expect(jsonData.vendor.addresses).to.be.an('array');",
" pm.expect(jsonData.vendor).to.have.property('phoneNumbers');",
" pm.expect(jsonData.vendor).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.vendor).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.vendor).to.have.property('remoteDeleted');",
" pm.expect(jsonData.vendor).to.have.property('createdAt');",
" pm.expect(jsonData.vendor).to.have.property('updatedAt');",
" pm.expect(jsonData.vendor).to.have.property('id');",
" if(jsonData.vendor.addresses.length > 0) {",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('addressType');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('street1');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('street2');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('city');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('state');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('country');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('countrySubdivision');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('country');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('zipCode');",
" }",
"});",
""
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
},
"disableBodyPruning": true
},
"request": {
"method": "GET",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/vendors/{{vendorId}}?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"vendors",
"{{vendorId}}"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Create Item",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 422\"] = responseCode.code === 422;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"Status code is 422\", function () {",
" pm.response.to.have.status(422);",
"});",
"",
"pm.test(\"Body has code and message\", function () {",
" let jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('code');",
" pm.expect(jsonData).to.have.property('message');",
"});",
"",
"pm.test(\"Code is OPERATION_NOT_SUPPORTED\", function () {",
" let jsonData = pm.response.json();",
" pm.expect(jsonData.code).to.eql(\"OPERATION_NOT_SUPPORTED\");",
"});"
],
"type": "text/javascript"
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "POST",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"itemName\": \"{{$randomAdjective}} {{$randomNoun}} Item\",\n \"itemType\": \"SERVICE\",\n \"billAccountId\": \"{{accountId}}\"\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/items?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": ["{{API_VERSION}}", "one", "accounting", "items"],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Create Payment",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] payment is created correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('payment');",
" pm.expect(jsonData.payment).to.not.be.null;",
" pm.expect(jsonData.payment).to.have.property('remoteId');",
" pm.expect(jsonData.payment).to.have.property('transactionDate');",
" pm.expect(jsonData.payment).to.have.property('customerId');",
" pm.expect(jsonData.payment).to.have.property('vendorId');",
" pm.expect(jsonData.payment).to.have.property('accountId');",
" pm.expect(jsonData.payment).to.have.property('currency');",
" pm.expect(jsonData.payment).to.have.property('exchangeRate');",
" pm.expect(jsonData.payment).to.have.property('companyId');",
" pm.expect(jsonData.payment).to.have.property('totalAmount');",
" pm.expect(jsonData.payment).to.have.property('trackingCategoryIds');",
" pm.expect(jsonData.payment).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.payment).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.payment).to.have.property('remoteDeleted');",
" pm.expect(jsonData.payment).to.have.property('createdAt');",
" pm.expect(jsonData.payment).to.have.property('updatedAt');",
" pm.expect(jsonData.payment).to.have.property('id');",
" pm.expect(jsonData.payment.totalAmount).to.equal(10);",
"});",
"",
"var jsonData = pm.response.json();",
"let paymentId = jsonData.payment.id;",
"postman.setEnvironmentVariable(\"paymentId\", paymentId);",
""
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "POST",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"customerId\": \"{{customerId}}\",\n \"totalAmount\": 10\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/payments?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": ["{{API_VERSION}}", "one", "accounting", "payments"],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Retrieve Payment",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] payment is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('payment');",
" pm.expect(jsonData.payment).to.not.be.null;",
" pm.expect(jsonData.payment).to.have.property('remoteId');",
" pm.expect(jsonData.payment).to.have.property('transactionDate');",
" pm.expect(jsonData.payment).to.have.property('customerId');",
" pm.expect(jsonData.payment).to.have.property('vendorId');",
" pm.expect(jsonData.payment).to.have.property('accountId');",
" pm.expect(jsonData.payment).to.have.property('currency');",
" pm.expect(jsonData.payment).to.have.property('exchangeRate');",
" pm.expect(jsonData.payment).to.have.property('companyId');",
" pm.expect(jsonData.payment).to.have.property('totalAmount');",
" pm.expect(jsonData.payment).to.have.property('trackingCategoryIds');",
" pm.expect(jsonData.payment).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.payment).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.payment).to.have.property('remoteDeleted');",
" pm.expect(jsonData.payment).to.have.property('createdAt');",
" pm.expect(jsonData.payment).to.have.property('updatedAt');",
" pm.expect(jsonData.payment).to.have.property('id');",
"});",
""
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
},
"disableBodyPruning": true
},
"request": {
"method": "GET",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/payments/{{paymentId}}?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"payments",
"{{paymentId}}"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Create Account For Create PO",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] account is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData.account).to.not.be.null;",
" pm.expect(jsonData.account).to.have.property('remoteId');",
" pm.expect(jsonData.account).to.have.property('accountName');",
" pm.expect(jsonData.account).to.have.property('accountDescription');",
" pm.expect(jsonData.account).to.have.property('classification');",
" pm.expect(jsonData.account).to.have.property('accountType');",
" pm.expect(jsonData.account).to.have.property('accountStatus');",
" pm.expect(jsonData.account).to.have.property('currentBalance');",
" pm.expect(jsonData.account).to.have.property('currency');",
" pm.expect(jsonData.account).to.have.property('accountNumber');",
" pm.expect(jsonData.account).to.have.property('parentAccountId');",
" pm.expect(jsonData.account).to.have.property('companyId');",
" pm.expect(jsonData.account).to.have.property('id');",
" pm.expect(jsonData.account.classification).to.equal('ASSET');",
" pm.expect(jsonData.account.accountType).to.equal('BANK');",
" pm.expect(jsonData.account.currency).to.equal('USD');",
"});",
"",
"var jsonData = pm.response.json();",
"let accountId = jsonData.account.id;",
"postman.setEnvironmentVariable(\"accountIdForCreatePO\", accountId);"
],
"type": "text/javascript"
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "POST",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"accountName\": \"{{$randomBankAccountName}}+{{$randomUUID}}\",\n \"accountType\": \"BANK\",\n \"currency\": \"USD\"\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/accounts?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": ["{{API_VERSION}}", "one", "accounting", "accounts"],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Get Item For Create PO",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] items are listed correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('items');",
" pm.expect(jsonData.items[0]).to.not.be.null;",
" pm.expect(jsonData.items[0]).to.have.property('remoteId');",
" pm.expect(jsonData.items[0]).to.have.property('itemName');",
" pm.expect(jsonData.items[0]).to.have.property('itemStatus');",
" pm.expect(jsonData.items[0]).to.have.property('itemType');",
" pm.expect(jsonData.items[0]).to.have.property('unitPrice');",
" pm.expect(jsonData.items[0]).to.have.property('purchasePrice');",
" pm.expect(jsonData.items[0]).to.have.property('qtyOnHand');",
" pm.expect(jsonData.items[0]).to.have.property('billAccountId');",
" pm.expect(jsonData.items[0]).to.have.property('invoiceAccountId');",
" pm.expect(jsonData.items[0]).to.have.property('assetAccountId');",
" pm.expect(jsonData.items[0]).to.have.property('companyId');",
" pm.expect(jsonData.items[0]).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.items[0]).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.items[0]).to.have.property('remoteDeleted');",
" pm.expect(jsonData.items[0]).to.have.property('createdAt');",
" pm.expect(jsonData.items[0]).to.have.property('updatedAt');",
" pm.expect(jsonData.items[0]).to.have.property('id');",
"});",
"",
"console.log(pm.response.json());",
"",
"var jsonData = pm.response.json();",
"let itemId = jsonData.items[0].id;",
"postman.setEnvironmentVariable(\"itemIdForCreatePO\", itemId);"
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
},
"disableBodyPruning": true
},
"request": {
"method": "GET",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/items?credentialId={{nsCredentialId}}&itemType=INVENTORY",
"host": ["{{URL}}"],
"path": ["{{API_VERSION}}", "one", "accounting", "items"],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
},
{
"key": "itemType",
"value": "INVENTORY"
}
]
}
},
"response": []
},
{
"name": "Create Purchase Order",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] purchase order is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('purchaseOrder');",
" pm.expect(jsonData.purchaseOrder).to.not.be.null;",
" pm.expect(jsonData.purchaseOrder).to.have.property('remoteId');",
" pm.expect(jsonData.purchaseOrder).to.have.property('purchaseOrderStatus');",
" pm.expect(jsonData.purchaseOrder).to.have.property('issueDate');",
" pm.expect(jsonData.purchaseOrder).to.have.property('purchaseOrderNumber');",
" pm.expect(jsonData.purchaseOrder).to.have.property('deliveryDate');",
" pm.expect(jsonData.purchaseOrder).to.have.property('deliveryAddress');",
" pm.expect(jsonData.purchaseOrder).to.have.property('vendorId');",
" pm.expect(jsonData.purchaseOrder).to.have.property('accountId');",
" pm.expect(jsonData.purchaseOrder).to.have.property('memo');",
" pm.expect(jsonData.purchaseOrder).to.have.property('companyId');",
" pm.expect(jsonData.purchaseOrder).to.have.property('totalAmount');",
" pm.expect(jsonData.purchaseOrder).to.have.property('currency');",
" pm.expect(jsonData.purchaseOrder).to.have.property('exchangeRate');",
" pm.expect(jsonData.purchaseOrder).to.have.property('lineItems');",
" pm.expect(jsonData.purchaseOrder).to.have.property('trackingCategoryIds');",
" pm.expect(jsonData.purchaseOrder).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.purchaseOrder).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.purchaseOrder).to.have.property('remoteDeleted');",
" pm.expect(jsonData.purchaseOrder).to.have.property('createdAt');",
" pm.expect(jsonData.purchaseOrder).to.have.property('updatedAt');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('id');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('remoteId');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('description');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('unitPrice');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('quantity');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('accountingItemId');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('accountId');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('trackingCategoryId');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('taxAmount');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('totalLineAmount');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('currency');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('trackingCategoryIds');",
"});",
"",
"var jsonData = pm.response.json();",
"let purchaseOrderId = jsonData.purchaseOrder.id;",
"let purchaseOrderLineItemId = jsonData.purchaseOrder.lineItems[0].id;",
"postman.setEnvironmentVariable(\"purchaseOrderId\", purchaseOrderId);",
"postman.setEnvironmentVariable(\"purchaseOrderLineItemId\", purchaseOrderLineItemId)",
"console.log(jsonData);"
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "POST",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"vendorId\": \"{{vendorId}}\",\n \"lineItems\": [{\n \"description\": \"{{$randomAdjective}} 1\",\n \"accountingItemId\": \"{{itemIdForCreatePO}}\",\n \"totalLineAmount\": 100\n }]\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/purchase-orders?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"purchase-orders"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Retrieve Purchase Order",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"purchase order is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('purchaseOrder');",
" pm.expect(jsonData.purchaseOrder).to.not.be.null;",
" pm.expect(jsonData.purchaseOrder).to.have.property('remoteId');",
" pm.expect(jsonData.purchaseOrder).to.have.property('purchaseOrderStatus');",
" pm.expect(jsonData.purchaseOrder).to.have.property('issueDate');",
" pm.expect(jsonData.purchaseOrder).to.have.property('purchaseOrderNumber');",
" pm.expect(jsonData.purchaseOrder).to.have.property('deliveryDate');",
" pm.expect(jsonData.purchaseOrder).to.have.property('deliveryAddress');",
" pm.expect(jsonData.purchaseOrder).to.have.property('vendorId');",
" pm.expect(jsonData.purchaseOrder).to.have.property('accountId');",
" pm.expect(jsonData.purchaseOrder).to.have.property('memo');",
" pm.expect(jsonData.purchaseOrder).to.have.property('companyId');",
" pm.expect(jsonData.purchaseOrder).to.have.property('totalAmount');",
" pm.expect(jsonData.purchaseOrder).to.have.property('currency');",
" pm.expect(jsonData.purchaseOrder).to.have.property('exchangeRate');",
" pm.expect(jsonData.purchaseOrder).to.have.property('lineItems');",
" pm.expect(jsonData.purchaseOrder).to.have.property('trackingCategoryIds');",
" pm.expect(jsonData.purchaseOrder).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.purchaseOrder).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.purchaseOrder).to.have.property('remoteDeleted');",
" pm.expect(jsonData.purchaseOrder).to.have.property('createdAt');",
" pm.expect(jsonData.purchaseOrder).to.have.property('updatedAt');",
" pm.expect(jsonData.purchaseOrder).to.have.property('id');",
"});",
"console.log(pm.response.json());"
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
},
"disableBodyPruning": true
},
"request": {
"method": "GET",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/purchase-orders/{{purchaseOrderId}}?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"purchase-orders",
"{{purchaseOrderId}}"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Update Purchase Order",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] purchase order is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('purchaseOrder');",
" pm.expect(jsonData.purchaseOrder).to.not.be.null;",
" pm.expect(jsonData.purchaseOrder).to.have.property('remoteId');",
" pm.expect(jsonData.purchaseOrder).to.have.property('purchaseOrderStatus');",
" pm.expect(jsonData.purchaseOrder).to.have.property('issueDate');",
" pm.expect(jsonData.purchaseOrder).to.have.property('purchaseOrderNumber');",
" pm.expect(jsonData.purchaseOrder).to.have.property('deliveryDate');",
" pm.expect(jsonData.purchaseOrder).to.have.property('deliveryAddress');",
" pm.expect(jsonData.purchaseOrder).to.have.property('vendorId');",
" pm.expect(jsonData.purchaseOrder).to.have.property('accountId');",
" pm.expect(jsonData.purchaseOrder).to.have.property('memo');",
" pm.expect(jsonData.purchaseOrder).to.have.property('companyId');",
" pm.expect(jsonData.purchaseOrder).to.have.property('totalAmount');",
" pm.expect(jsonData.purchaseOrder).to.have.property('currency');",
" pm.expect(jsonData.purchaseOrder).to.have.property('exchangeRate');",
" pm.expect(jsonData.purchaseOrder).to.have.property('lineItems');",
" pm.expect(jsonData.purchaseOrder).to.have.property('trackingCategoryIds');",
" pm.expect(jsonData.purchaseOrder).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.purchaseOrder).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.purchaseOrder).to.have.property('remoteDeleted');",
" pm.expect(jsonData.purchaseOrder).to.have.property('createdAt');",
" pm.expect(jsonData.purchaseOrder).to.have.property('updatedAt');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('id');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('remoteId');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('description');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('unitPrice');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('quantity');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('accountingItemId');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('accountId');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('trackingCategoryId');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('taxAmount');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('totalLineAmount');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('currency');",
" pm.expect(jsonData.purchaseOrder.lineItems[0]).to.have.property('trackingCategoryIds');",
" pm.expect(jsonData.purchaseOrder.lineItems.length).to.equal(2);",
"});",
"console.log(pm.request.body);",
"console.log(pm.response.json());"
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "PUT",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"vendorId\": \"{{vendorId}}\",\n \"lineItems\": [\n {\n \"id\": \"{{purchaseOrderLineItemId}}\",\n \"description\": \"{{$randomAdjective}} - Updated\",\n \"accountingItemId\": \"{{itemIdForCreatePO}}\",\n \"quantity\": 2,\n \"totalLineAmount\": 200\n },\n {\n \"description\": \"{{$randomAdjective}} - New\",\n \"accountingItemId\": \"{{itemIdForCreatePO}}\",\n \"quantity\": 2,\n \"totalLineAmount\": 300\n }\n ]\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/purchase-orders/{{purchaseOrderId}}?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"purchase-orders",
"{{purchaseOrderId}}"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Get Item For Create Bill",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] items are listed correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('items');",
" pm.expect(jsonData.items[0]).to.not.be.null;",
" pm.expect(jsonData.items[0]).to.have.property('remoteId');",
" pm.expect(jsonData.items[0]).to.have.property('itemName');",
" pm.expect(jsonData.items[0]).to.have.property('itemStatus');",
" pm.expect(jsonData.items[0]).to.have.property('itemType');",
" pm.expect(jsonData.items[0]).to.have.property('unitPrice');",
" pm.expect(jsonData.items[0]).to.have.property('purchasePrice');",
" pm.expect(jsonData.items[0]).to.have.property('qtyOnHand');",
" pm.expect(jsonData.items[0]).to.have.property('billAccountId');",
" pm.expect(jsonData.items[0]).to.have.property('invoiceAccountId');",
" pm.expect(jsonData.items[0]).to.have.property('assetAccountId');",
" pm.expect(jsonData.items[0]).to.have.property('companyId');",
" pm.expect(jsonData.items[0]).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.items[0]).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.items[0]).to.have.property('remoteDeleted');",
" pm.expect(jsonData.items[0]).to.have.property('createdAt');",
" pm.expect(jsonData.items[0]).to.have.property('updatedAt');",
" pm.expect(jsonData.items[0]).to.have.property('id');",
"});",
"",
"var jsonData = pm.response.json();",
"let itemId = jsonData.items[0].id;",
"postman.setEnvironmentVariable(\"itemIdForCreateBill\", itemId);"
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
},
"disableBodyPruning": true
},
"request": {
"method": "GET",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/items?credentialId={{nsCredentialId}}&itemType=INVENTORY",
"host": ["{{URL}}"],
"path": ["{{API_VERSION}}", "one", "accounting", "items"],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
},
{
"key": "itemType",
"value": "INVENTORY"
}
]
}
},
"response": []
},
{
"name": "Create Bill",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"bill is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('bill');",
" pm.expect(jsonData.bill).to.not.be.null;",
" pm.expect(jsonData.bill).to.have.property('remoteId');",
" pm.expect(jsonData.bill).to.have.property('vendorId');",
" pm.expect(jsonData.bill).to.have.property('billNumber');",
" pm.expect(jsonData.bill).to.have.property('issueDate');",
" pm.expect(jsonData.bill).to.have.property('dueDate');",
" pm.expect(jsonData.bill).to.have.property('paidOnDate');",
" pm.expect(jsonData.bill).to.have.property('memo');",
" pm.expect(jsonData.bill).to.have.property('companyId');",
" pm.expect(jsonData.bill).to.have.property('currency');",
" pm.expect(jsonData.bill).to.have.property('exchangeRate');",
" pm.expect(jsonData.bill).to.have.property('totalDiscount');",
" pm.expect(jsonData.bill).to.have.property('subTotal');",
" pm.expect(jsonData.bill).to.have.property('billStatus');",
" pm.expect(jsonData.bill).to.have.property('totalTaxAmount');",
" pm.expect(jsonData.bill).to.have.property('totalAmount');",
" pm.expect(jsonData.bill).to.have.property('balance');",
" pm.expect(jsonData.bill).to.have.property('trackingCategories');",
" pm.expect(jsonData.bill).to.have.property('lineItems');",
" pm.expect(jsonData.bill).to.have.property('purchaseOrders');",
" pm.expect(jsonData.bill).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.bill).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.bill).to.have.property('remoteDeleted');",
" pm.expect(jsonData.bill).to.have.property('createdAt');",
" pm.expect(jsonData.bill).to.have.property('updatedAt');",
" pm.expect(jsonData.bill).to.have.property('id');",
" pm.expect(jsonData.bill.billNumber).to.equal('PLDT-001');",
" pm.expect(jsonData.bill.lineItems[0].description).to.equal('Line Item 1');",
" pm.expect(jsonData.bill.lineItems[0].totalAmount).to.equal(100);",
"});",
"",
"var jsonData = pm.response.json();",
"let billId = jsonData.bill.id;",
"let billLineItemId = jsonData.bill.lineItems[0].id;",
"postman.setEnvironmentVariable(\"billId\", billId);",
"postman.setEnvironmentVariable(\"billLineItemId\", billLineItemId);"
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "POST",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"vendorId\": \"{{vendorId}}\",\n \"billNumber\": \"PLDT-001\",\n \"lineItems\": [\n {\n \"description\": \"Line Item 1\",\n \"accountingItemId\": \"{{itemIdForCreateBill}}\",\n \"totalAmount\": 100\n }\n ]\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/bills?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": ["{{API_VERSION}}", "one", "accounting", "bills"],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Retrieve Bill",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] bill is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('bill');",
" pm.expect(jsonData.bill).to.not.be.null;",
" pm.expect(jsonData.bill).to.have.property('remoteId');",
" pm.expect(jsonData.bill).to.have.property('vendorId');",
" pm.expect(jsonData.bill).to.have.property('billNumber');",
" pm.expect(jsonData.bill).to.have.property('issueDate');",
" pm.expect(jsonData.bill).to.have.property('dueDate');",
" pm.expect(jsonData.bill).to.have.property('paidOnDate');",
" pm.expect(jsonData.bill).to.have.property('memo');",
" pm.expect(jsonData.bill).to.have.property('companyId');",
" pm.expect(jsonData.bill).to.have.property('currency');",
" pm.expect(jsonData.bill).to.have.property('exchangeRate');",
" pm.expect(jsonData.bill).to.have.property('totalDiscount');",
" pm.expect(jsonData.bill).to.have.property('subTotal');",
" pm.expect(jsonData.bill).to.have.property('billStatus');",
" pm.expect(jsonData.bill).to.have.property('totalTaxAmount');",
" pm.expect(jsonData.bill).to.have.property('totalAmount');",
" pm.expect(jsonData.bill).to.have.property('balance');",
" pm.expect(jsonData.bill).to.have.property('trackingCategories');",
" pm.expect(jsonData.bill).to.have.property('lineItems');",
" pm.expect(jsonData.bill).to.have.property('purchaseOrders');",
" pm.expect(jsonData.bill).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.bill).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.bill).to.have.property('remoteDeleted');",
" pm.expect(jsonData.bill).to.have.property('createdAt');",
" pm.expect(jsonData.bill).to.have.property('updatedAt');",
" pm.expect(jsonData.bill).to.have.property('id');",
" pm.expect(jsonData.bill.lineItems[0]).to.have.property('id');",
" pm.expect(jsonData.bill.lineItems[0]).to.have.property('remoteId');",
" pm.expect(jsonData.bill.lineItems[0]).to.have.property('description');",
" pm.expect(jsonData.bill.lineItems[0]).to.have.property('unitPrice');",
" pm.expect(jsonData.bill.lineItems[0]).to.have.property('quantity');",
" pm.expect(jsonData.bill.lineItems[0]).to.have.property('totalAmount');",
" pm.expect(jsonData.bill.lineItems[0]).to.have.property('currency');",
" pm.expect(jsonData.bill.lineItems[0]).to.have.property('exchangeRate');",
" pm.expect(jsonData.bill.lineItems[0]).to.have.property('accountingItemId');",
" pm.expect(jsonData.bill.lineItems[0]).to.have.property('accountId');",
" pm.expect(jsonData.bill.lineItems[0]).to.have.property('trackingCategoryId');",
" pm.expect(jsonData.bill.lineItems[0]).to.have.property('trackingCategoryIds');",
" pm.expect(jsonData.bill.lineItems[0]).to.have.property('companyId');",
"});",
""
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
},
"disableBodyPruning": true
},
"request": {
"method": "GET",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/bills/{{billId}}?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"bills",
"{{billId}}"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Get Item For Create Invoice",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] items are listed correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('items');",
" pm.expect(jsonData.items[0]).to.not.be.null;",
" pm.expect(jsonData.items[0]).to.have.property('remoteId');",
" pm.expect(jsonData.items[0]).to.have.property('itemName');",
" pm.expect(jsonData.items[0]).to.have.property('itemStatus');",
" pm.expect(jsonData.items[0]).to.have.property('itemType');",
" pm.expect(jsonData.items[0]).to.have.property('unitPrice');",
" pm.expect(jsonData.items[0]).to.have.property('purchasePrice');",
" pm.expect(jsonData.items[0]).to.have.property('qtyOnHand');",
" pm.expect(jsonData.items[0]).to.have.property('billAccountId');",
" pm.expect(jsonData.items[0]).to.have.property('invoiceAccountId');",
" pm.expect(jsonData.items[0]).to.have.property('assetAccountId');",
" pm.expect(jsonData.items[0]).to.have.property('companyId');",
" pm.expect(jsonData.items[0]).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.items[0]).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.items[0]).to.have.property('remoteDeleted');",
" pm.expect(jsonData.items[0]).to.have.property('createdAt');",
" pm.expect(jsonData.items[0]).to.have.property('updatedAt');",
" pm.expect(jsonData.items[0]).to.have.property('id');",
"});",
"",
"var jsonData = pm.response.json();",
"let itemId = jsonData.items[0].id;",
"postman.setEnvironmentVariable(\"itemIdForCreateInvoice\", itemId);"
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
},
"disableBodyPruning": true
},
"request": {
"method": "GET",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/items?credentialId={{nsCredentialId}}&itemType=INVENTORY",
"host": ["{{URL}}"],
"path": ["{{API_VERSION}}", "one", "accounting", "items"],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
},
{
"key": "itemType",
"value": "INVENTORY"
}
]
}
},
"response": []
},
{
"name": "Create Invoice",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] invoice is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('invoice');",
" pm.expect(jsonData.invoice).to.not.be.null;",
" pm.expect(jsonData.invoice).to.have.property('remoteId');",
" pm.expect(jsonData.invoice).to.have.property('customerId');",
" pm.expect(jsonData.invoice).to.have.property('invoiceNumber');",
" pm.expect(jsonData.invoice).to.have.property('issueDate');",
" pm.expect(jsonData.invoice).to.have.property('dueDate');",
" pm.expect(jsonData.invoice).to.have.property('paidOnDate');",
" pm.expect(jsonData.invoice).to.have.property('memo');",
" pm.expect(jsonData.invoice).to.have.property('companyId');",
" pm.expect(jsonData.invoice).to.have.property('currency');",
" pm.expect(jsonData.invoice).to.have.property('exchangeRate');",
" pm.expect(jsonData.invoice).to.have.property('totalDiscount');",
" pm.expect(jsonData.invoice).to.have.property('subTotal');",
" pm.expect(jsonData.invoice).to.have.property('invoiceStatus');",
" pm.expect(jsonData.invoice).to.have.property('totalTaxAmount');",
" pm.expect(jsonData.invoice).to.have.property('totalAmount');",
" pm.expect(jsonData.invoice).to.have.property('balance');",
" pm.expect(jsonData.invoice).to.have.property('trackingCategories');",
" pm.expect(jsonData.invoice).to.have.property('lineItems');",
" pm.expect(jsonData.invoice).to.have.property('purchaseOrders');",
" pm.expect(jsonData.invoice).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.invoice).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.invoice).to.have.property('remoteDeleted');",
" pm.expect(jsonData.invoice).to.have.property('createdAt');",
" pm.expect(jsonData.invoice).to.have.property('updatedAt');",
" pm.expect(jsonData.invoice).to.have.property('id');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('id');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('remoteId');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('description');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('unitPrice');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('quantity');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('totalAmount');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('currency');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('exchangeRate');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('accountingItemId');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('accountId');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('trackingCategoryId');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('trackingCategoryIds');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('companyId');",
"});",
"",
"var jsonData = pm.response.json();",
"let invoiceId = jsonData.invoice.id;",
"postman.setEnvironmentVariable(\"invoiceId\", invoiceId);",
"let invoiceLineItemId = jsonData.invoice.lineItems[0].id;",
"postman.setEnvironmentVariable(\"invoiceLineItemId\", invoiceLineItemId);"
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "POST",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"customerId\": \"{{customerId}}\",\n \"invoiceNumber\": \"ALY-001\",\n \"lineItems\": [\n {\n \"description\": \"Francis Menguito - Developer\",\n \"totalAmount\": 10000,\n \"accountingItemId\": \"{{itemIdForCreateInvoice}}\"\n }\n ]\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/invoices?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": ["{{API_VERSION}}", "one", "accounting", "invoices"],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Retrieve Invoice",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"invoice is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('invoice');",
" pm.expect(jsonData.invoice).to.not.be.null;",
" pm.expect(jsonData.invoice).to.have.property('remoteId');",
" pm.expect(jsonData.invoice).to.have.property('customerId');",
" pm.expect(jsonData.invoice).to.have.property('invoiceNumber');",
" pm.expect(jsonData.invoice).to.have.property('issueDate');",
" pm.expect(jsonData.invoice).to.have.property('dueDate');",
" pm.expect(jsonData.invoice).to.have.property('paidOnDate');",
" pm.expect(jsonData.invoice).to.have.property('memo');",
" pm.expect(jsonData.invoice).to.have.property('companyId');",
" pm.expect(jsonData.invoice).to.have.property('currency');",
" pm.expect(jsonData.invoice).to.have.property('exchangeRate');",
" pm.expect(jsonData.invoice).to.have.property('totalDiscount');",
" pm.expect(jsonData.invoice).to.have.property('subTotal');",
" pm.expect(jsonData.invoice).to.have.property('invoiceStatus');",
" pm.expect(jsonData.invoice).to.have.property('totalTaxAmount');",
" pm.expect(jsonData.invoice).to.have.property('totalAmount');",
" pm.expect(jsonData.invoice).to.have.property('balance');",
" pm.expect(jsonData.invoice).to.have.property('trackingCategories');",
" pm.expect(jsonData.invoice).to.have.property('lineItems');",
" pm.expect(jsonData.invoice).to.have.property('purchaseOrders');",
" pm.expect(jsonData.invoice).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.invoice).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.invoice).to.have.property('remoteDeleted');",
" pm.expect(jsonData.invoice).to.have.property('createdAt');",
" pm.expect(jsonData.invoice).to.have.property('updatedAt');",
" pm.expect(jsonData.invoice).to.have.property('id');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('id');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('remoteId');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('description');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('unitPrice');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('quantity');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('totalAmount');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('currency');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('exchangeRate');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('accountingItemId');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('accountId');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('trackingCategoryId');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('trackingCategoryIds');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('companyId');",
"});",
""
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
},
"disableBodyPruning": true
},
"request": {
"method": "GET",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/invoices/{{invoiceId}}?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"invoices",
"{{invoiceId}}"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
}
]
},
{
"name": "03 Update",
"item": [
{
"name": "Update Account",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"account is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData.account).to.not.be.null;",
" pm.expect(jsonData.account).to.have.property('remoteId');",
" pm.expect(jsonData.account).to.have.property('accountName');",
" pm.expect(jsonData.account).to.have.property('accountDescription');",
" pm.expect(jsonData.account).to.have.property('classification');",
" pm.expect(jsonData.account).to.have.property('accountType');",
" pm.expect(jsonData.account).to.have.property('accountStatus');",
" pm.expect(jsonData.account).to.have.property('currentBalance');",
" pm.expect(jsonData.account).to.have.property('currency');",
" pm.expect(jsonData.account).to.have.property('accountNumber');",
" pm.expect(jsonData.account).to.have.property('parentAccountId');",
" pm.expect(jsonData.account).to.have.property('companyId');",
" pm.expect(jsonData.account).to.have.property('id');",
" pm.expect(jsonData.account).to.have.property('remoteDeleted');",
" pm.expect(jsonData.account).to.have.property('createdAt');",
" pm.expect(jsonData.account).to.have.property('updatedAt');",
"});"
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "PUT",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"accountName\": \"CachoChildren+{{$randomUUID}}\"\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/accounts/{{accountId}}?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"accounts",
"{{accountId}}"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Update Customer",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"customer is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('customer');",
" pm.expect(jsonData.customer).to.not.be.null;",
" pm.expect(jsonData.customer).to.have.property('remoteId');",
" pm.expect(jsonData.customer).to.have.property('customerName');",
" pm.expect(jsonData.customer).to.have.property('email');",
" pm.expect(jsonData.customer).to.have.property('taxNumber');",
" pm.expect(jsonData.customer).to.have.property('customerStatus');",
" pm.expect(jsonData.customer).to.have.property('currency');",
" pm.expect(jsonData.customer).to.have.property('companyId');",
" pm.expect(jsonData.customer).to.have.property('addresses');",
" pm.expect(jsonData.customer).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.customer).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.customer).to.have.property('remoteDeleted');",
" pm.expect(jsonData.customer).to.have.property('createdAt');",
" pm.expect(jsonData.customer).to.have.property('updatedAt');",
" pm.expect(jsonData.customer).to.have.property('id');",
" pm.expect(jsonData.customer.customerName).to.include(\"AlloyUpdate\");",
" pm.expect(jsonData.customer.addresses).to.be.an('array').that.is.not.empty;",
" pm.expect(jsonData.customer.addresses[0].street1).to.include(\"Lombard\");",
" pm.expect(jsonData.customer.addresses[0].zipCode).to.include(\"94012\");",
"});",
""
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "PUT",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"customerName\": \"AlloyUpdate+{{$randomUUID}}\",\n \"addresses\": [\n { \n \"remoteId\": \"{{customerAddressRemoteId}}\",\n \"addressType\": \"BILLING\",\n \"street1\": \"Lombard\",\n \"zipCode\": \"94012\",\n \"country\": \"US\"\n }\n ],\n \"phoneNumbers\": [\n {\n \"phoneNumberType\": \"MOBILE\",\n \"phoneNumber\": \"09173210215\"\n }\n ]\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/customers/{{customerId}}?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"customers",
"{{customerId}}"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Update Vendor",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"vendor is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('vendor');",
" pm.expect(jsonData.vendor).to.not.be.null;",
" pm.expect(jsonData.vendor).to.have.property('remoteId');",
" pm.expect(jsonData.vendor).to.have.property('vendorName');",
" pm.expect(jsonData.vendor).to.have.property('email');",
" pm.expect(jsonData.vendor).to.have.property('taxNumber');",
" pm.expect(jsonData.vendor).to.have.property('vendorStatus');",
" pm.expect(jsonData.vendor).to.have.property('currency');",
" pm.expect(jsonData.vendor).to.have.property('companyId');",
" pm.expect(jsonData.vendor).to.have.property('addresses');",
" pm.expect(jsonData.vendor.addresses).to.be.an('array').that.is.not.empty;",
" pm.expect(jsonData.vendor).to.have.property('phoneNumbers');",
" pm.expect(jsonData.vendor).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.vendor).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.vendor).to.have.property('remoteDeleted');",
" pm.expect(jsonData.vendor).to.have.property('createdAt');",
" pm.expect(jsonData.vendor).to.have.property('updatedAt');",
" pm.expect(jsonData.vendor).to.have.property('id');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('addressType');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('street1');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('street2');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('city');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('state');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('country');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('countrySubdivision');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('country');",
" pm.expect(jsonData.vendor.addresses[0]).to.have.property('zipCode');",
" pm.expect(jsonData.vendor.addresses[0].street1).to.equal('Dan Troy');",
" pm.expect(jsonData.vendor.addresses[0].zipCode).to.equal('14221');",
" pm.expect(jsonData.vendor.vendorName).to.include(\"AlloyUpdate\");",
"});",
""
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "PUT",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"vendorName\": \"AlloyUpdate+{{$randomUUID}}\",\n \"vendorStatus\": \"ACTIVE\",\n \"addresses\": [\n { \n \"remoteId\": \"{{vendorAddressRemoteId}}\",\n \"addressType\": \"BILLING\",\n \"street1\": \"Dan Troy\",\n \"zipCode\": \"14221\",\n \"country\": \"US\"\n }\n ],\n \"phoneNumbers\": [\n {\n \"phoneNumberType\": \"MOBILE\",\n \"phoneNumber\": \"09173210215\"\n }\n ]\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/vendors/{{vendorId}}?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"vendors",
"{{vendorId}}"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Update Payment",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"payment is created correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('payment');",
" pm.expect(jsonData.payment).to.not.be.null;",
" pm.expect(jsonData.payment).to.have.property('remoteId');",
" pm.expect(jsonData.payment).to.have.property('transactionDate');",
" pm.expect(jsonData.payment).to.have.property('customerId');",
" pm.expect(jsonData.payment).to.have.property('vendorId');",
" pm.expect(jsonData.payment).to.have.property('accountId');",
" pm.expect(jsonData.payment).to.have.property('currency');",
" pm.expect(jsonData.payment).to.have.property('exchangeRate');",
" pm.expect(jsonData.payment).to.have.property('companyId');",
" pm.expect(jsonData.payment).to.have.property('totalAmount');",
" pm.expect(jsonData.payment).to.have.property('trackingCategoryIds');",
" pm.expect(jsonData.payment).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.payment).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.payment).to.have.property('remoteDeleted');",
" pm.expect(jsonData.payment).to.have.property('createdAt');",
" pm.expect(jsonData.payment).to.have.property('updatedAt');",
" pm.expect(jsonData.payment).to.have.property('id');",
" pm.expect(jsonData.payment.totalAmount).to.equal(100);",
"});",
"",
""
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "PUT",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"totalAmount\": 100\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/payments/{{paymentId}}?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"payments",
"{{paymentId}}"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Update Bill",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"bill is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('bill');",
" pm.expect(jsonData.bill).to.not.be.null;",
" pm.expect(jsonData.bill).to.have.property('remoteId');",
" pm.expect(jsonData.bill).to.have.property('vendorId');",
" pm.expect(jsonData.bill).to.have.property('billNumber');",
" pm.expect(jsonData.bill).to.have.property('issueDate');",
" pm.expect(jsonData.bill).to.have.property('dueDate');",
" pm.expect(jsonData.bill).to.have.property('paidOnDate');",
" pm.expect(jsonData.bill).to.have.property('memo');",
" pm.expect(jsonData.bill).to.have.property('companyId');",
" pm.expect(jsonData.bill).to.have.property('currency');",
" pm.expect(jsonData.bill).to.have.property('exchangeRate');",
" pm.expect(jsonData.bill).to.have.property('totalDiscount');",
" pm.expect(jsonData.bill).to.have.property('subTotal');",
" pm.expect(jsonData.bill).to.have.property('billStatus');",
" pm.expect(jsonData.bill).to.have.property('totalTaxAmount');",
" pm.expect(jsonData.bill).to.have.property('totalAmount');",
" pm.expect(jsonData.bill).to.have.property('balance');",
" pm.expect(jsonData.bill).to.have.property('trackingCategories');",
" pm.expect(jsonData.bill).to.have.property('lineItems');",
" pm.expect(jsonData.bill).to.have.property('purchaseOrders');",
" pm.expect(jsonData.bill).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.bill).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.bill).to.have.property('remoteDeleted');",
" pm.expect(jsonData.bill).to.have.property('createdAt');",
" pm.expect(jsonData.bill).to.have.property('updatedAt');",
" pm.expect(jsonData.bill).to.have.property('id');",
" pm.expect(jsonData.bill.billNumber).to.equal('PLDT-001');",
" pm.expect(jsonData.bill.lineItems[0].description).to.equal('Line Item 1');",
" pm.expect(jsonData.bill.lineItems[0].totalAmount).to.equal(200);",
" pm.expect(jsonData.bill.lineItems.length).to.equal(2);",
"});",
""
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "PUT",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"vendorId\": \"{{vendorId}}\",\n \"billNumber\": \"PLDT-001\",\n \"lineItems\": [\n {\n \"id\": \"{{billLineItemId}}\",\n \"description\": \"Line Item 1\",\n \"accountingItemId\": \"{{itemIdForCreateBill}}\",\n \"totalAmount\": 200\n },\n {\n \"description\": \"Line Item 2\",\n \"accountingItemId\": \"{{itemIdForCreateBill}}\",\n \"totalAmount\": 300\n }\n ]\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/bills/{{billId}}?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"bills",
"{{billId}}"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Update Invoice",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 200\"] = responseCode.code === 200;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"response should be okay to process\", function () {",
" pm.response.to.have.status(200);",
" pm.response.to.not.be.error;",
" pm.response.to.not.have.jsonBody(\"error\");",
"});",
"",
"pm.test(\"[netsuite] invoice is retrieved correctly\", function () {",
" var jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('invoice');",
" pm.expect(jsonData.invoice).to.not.be.null;",
" pm.expect(jsonData.invoice).to.have.property('remoteId');",
" pm.expect(jsonData.invoice).to.have.property('customerId');",
" pm.expect(jsonData.invoice).to.have.property('invoiceNumber');",
" pm.expect(jsonData.invoice).to.have.property('issueDate');",
" pm.expect(jsonData.invoice).to.have.property('dueDate');",
" pm.expect(jsonData.invoice).to.have.property('paidOnDate');",
" pm.expect(jsonData.invoice).to.have.property('memo');",
" pm.expect(jsonData.invoice).to.have.property('companyId');",
" pm.expect(jsonData.invoice).to.have.property('currency');",
" pm.expect(jsonData.invoice).to.have.property('exchangeRate');",
" pm.expect(jsonData.invoice).to.have.property('totalDiscount');",
" pm.expect(jsonData.invoice).to.have.property('subTotal');",
" pm.expect(jsonData.invoice).to.have.property('invoiceStatus');",
" pm.expect(jsonData.invoice).to.have.property('totalTaxAmount');",
" pm.expect(jsonData.invoice).to.have.property('totalAmount');",
" pm.expect(jsonData.invoice).to.have.property('balance');",
" pm.expect(jsonData.invoice).to.have.property('trackingCategories');",
" pm.expect(jsonData.invoice).to.have.property('lineItems');",
" pm.expect(jsonData.invoice).to.have.property('purchaseOrders');",
" pm.expect(jsonData.invoice).to.have.property('remoteCreatedAt');",
" pm.expect(jsonData.invoice).to.have.property('remoteUpdatedAt');",
" pm.expect(jsonData.invoice).to.have.property('remoteDeleted');",
" pm.expect(jsonData.invoice).to.have.property('createdAt');",
" pm.expect(jsonData.invoice).to.have.property('updatedAt');",
" pm.expect(jsonData.invoice).to.have.property('id');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('id');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('remoteId');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('description');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('unitPrice');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('quantity');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('totalAmount');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('currency');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('exchangeRate');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('accountingItemId');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('accountId');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('trackingCategoryId');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('trackingCategoryIds');",
" pm.expect(jsonData.invoice.lineItems[0]).to.have.property('companyId');",
" pm.expect(jsonData.invoice.lineItems.length).to.equal(2);",
"});",
"",
"console.log(pm.response.json());",
""
],
"type": "text/javascript",
"packages": {}
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
}
},
"request": {
"method": "PUT",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"customerId\": \"{{customerId}}\",\n \"invoiceNumber\": \"ALY-001\",\n \"lineItems\": [\n {\n \"id\": \"{{invoiceLineItemId}}\",\n \"description\": \"Francis Menguito - Developer\",\n \"totalAmount\": 15000,\n \"accountingItemId\": \"{{itemIdForCreateInvoice}}\"\n },\n {\n \"description\": \"Maynard Cantay - Developer\",\n \"totalAmount\": 10000,\n \"accountingItemId\": \"{{itemIdForCreateInvoice}}\"\n }\n ]\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/invoices/{{invoiceId}}?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"invoices",
"{{invoiceId}}"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
}
]
},
{
"name": "04 List and Count",
"item": [
{
"name": "List Company Info",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 501\"] = responseCode.code === 501;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"Status code is 501\", function () {",
" pm.response.to.have.status(501);",
"});",
"",
"pm.test(\"Body has code and message\", function () {",
" let jsonData = pm.response.json();",
" console.log(jsonData);",
" pm.expect(jsonData).to.have.property('code');",
" pm.expect(jsonData).to.have.property('message');",
"});",
"",
"pm.test(\"Code is MODEL_NOT_SUPPORTED\", function () {",
" let jsonData = pm.response.json();",
" pm.expect(jsonData.code).to.eql(\"MODEL_NOT_SUPPORTED\");",
"});"
],
"type": "text/javascript"
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
},
"disableBodyPruning": true
},
"request": {
"method": "GET",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/company-info?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": ["{{API_VERSION}}", "one", "accounting", "company-info"],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Get Company Info Count",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 501\"] = responseCode.code === 501;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"Status code is 501\", function () {",
" pm.response.to.have.status(501);",
"});",
"",
"pm.test(\"Body has code and message\", function () {",
" let jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('code');",
" pm.expect(jsonData).to.have.property('message');",
"});",
"",
"pm.test(\"Code is MODEL_NOT_SUPPORTED\", function () {",
" let jsonData = pm.response.json();",
" pm.expect(jsonData.code).to.eql(\"MODEL_NOT_SUPPORTED\");",
"});"
],
"type": "text/javascript"
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
},
"disableBodyPruning": true
},
"request": {
"method": "GET",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{URL}}/{{API_VERSION}}/one/accounting/company-info/count?credentialId={{nsCredentialId}}",
"host": ["{{URL}}"],
"path": [
"{{API_VERSION}}",
"one",
"accounting",
"company-info",
"count"
],
"query": [
{
"key": "credentialId",
"value": "{{nsCredentialId}}"
}
]
}
},
"response": []
},
{
"name": "Retrieve Company Info",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Status code is 501\"] = responseCode.code === 501;",
"",
"var contentTypeHeaderExists = responseHeaders.hasOwnProperty(\"Content-Type\");",
"tests[\"Has Content-Type\"] = contentTypeHeaderExists;",
" ",
"if (contentTypeHeaderExists) {",
" tests[\"Content-Type is application/json\"] = ",
" responseHeaders[\"Content-Type\"].has(\"application/json\");",
"}",
"",
"pm.test(\"Status code is 501\", function () {",
" pm.response.to.have.status(501);",
"});",
"",
"pm.test(\"Body has code and message\", function () {",
" let jsonData = pm.response.json();",
" pm.expect(jsonData).to.have.property('code');",
" pm.expect(jsonData).to.have.property('message');",
"});",
"",
"pm.test(\"Code is MODEL_NOT_SUPPORTED\", function () {",
" let jsonData = pm.response.json();",
" pm.expect(jsonData.code).to.eql(\"MODEL_NOT_SUPPORTED\");",
"});"
],
"type": "text/javascript"
}
}
],
"protocolProfileBehavior": {
"disabledSystemHeaders": {
"accept": true
},
"disableBodyPruning": true
},
"request": {
"method": "GET",
"header": [
{
"key": "Authorization",
"value": "Bearer {{apiKey}}",
"type": "text"
},
{
"key": "Accept",
"value": "application/json",
"type": "text"
}
],
"body"