From 1bd9920e7925b20d32a1efd6f68559ac1b516d4f Mon Sep 17 00:00:00 2001 From: malachewhiz Date: Mon, 5 Dec 2022 09:32:31 +0100 Subject: [PATCH] Add order model (#116) We add accessors for the `api/v1/orders` endpoint to create, find and delete orders, including related models. Co-authored-by: Steffen [sc-15085](https://app.shortcut.com/shipcloud/story/15085) --- lib/shipcloud.rb | 1 + lib/shipcloud/order.rb | 15 +++ shipcloud.gemspec | 1 - spec/shipcloud/order_spec.rb | 188 +++++++++++++++++++++++++++++++++++ 4 files changed, 204 insertions(+), 1 deletion(-) create mode 100644 lib/shipcloud/order.rb create mode 100644 spec/shipcloud/order_spec.rb diff --git a/lib/shipcloud.rb b/lib/shipcloud.rb index 770bcd8..6ac61a0 100644 --- a/lib/shipcloud.rb +++ b/lib/shipcloud.rb @@ -21,6 +21,7 @@ module Shipcloud autoload :Shipment, "shipcloud/shipment" autoload :Carrier, "shipcloud/carrier" autoload :Address, "shipcloud/address" + autoload :Order, "shipcloud/order" autoload :PickupRequest, "shipcloud/pickup_request" autoload :ShipmentQuote, "shipcloud/shipment_quote" autoload :Tracker, "shipcloud/tracker" diff --git a/lib/shipcloud/order.rb b/lib/shipcloud/order.rb new file mode 100644 index 0000000..72b1f3d --- /dev/null +++ b/lib/shipcloud/order.rb @@ -0,0 +1,15 @@ +# frozen_string_literal: true + +module Shipcloud + class Order < Base + include Shipcloud::Operations::All + include Shipcloud::Operations::Find + include Shipcloud::Operations::Create + include Shipcloud::Operations::Delete + + attr_reader :id + attr_accessor :external_customer_id, :external_order_id, :placed_at, :total_price, :total_vat, + :currency, :total_weight, :weight_unit, :refundable_until, + :refund_deduction_amount, :delivery_address, :order_line_items, :metadata + end +end diff --git a/shipcloud.gemspec b/shipcloud.gemspec index 96914b4..76bbb5d 100644 --- a/shipcloud.gemspec +++ b/shipcloud.gemspec @@ -17,7 +17,6 @@ Gem::Specification.new do |spec| spec.license = "MIT" spec.files = `git ls-files`.split($/) - spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) } spec.test_files = spec.files.grep(%r{^(test|spec|features)/}) spec.require_paths = ["lib"] diff --git a/spec/shipcloud/order_spec.rb b/spec/shipcloud/order_spec.rb new file mode 100644 index 0000000..d78c443 --- /dev/null +++ b/spec/shipcloud/order_spec.rb @@ -0,0 +1,188 @@ +# frozen_string_literal: true +require "spec_helper" + +describe Shipcloud::Order do + describe "#initialize" do + it "initializes all attributes correctly" do + valid_attributes = { + external_order_id: "external_order_id", + external_customer_id: "external_customer_id", + refundable_until: "refundable_until", + total_weight: 12.34, + refund_deduction_amount: 4.32, + delivery_address: { + id: "adress_id", + }, + order_line_items: [ + { + id: "order_line_item_id", + }, + ], + } + order = Shipcloud::Order.new(valid_attributes) + + expect(order.external_order_id).to eq "external_order_id" + expect(order.external_customer_id).to eq "external_customer_id" + expect(order.refundable_until).to eq "refundable_until" + expect(order.total_weight).to eq 12.34 + expect(order.refund_deduction_amount).to eq 4.32 + expect(order.delivery_address).to eq(id: "adress_id") + expect(order.order_line_items).to eq [ + { id: "order_line_item_id" }, + ] + end + end + + describe ".all" do + it "executes a GET request to the 'orders' API endpoint" do + expect(Shipcloud).to receive(:request). + with(:get, "orders", {}, api_key: nil, affiliate_id: nil). + and_return([]) + + Shipcloud::Order.all + end + + it "returns a list of Order objects" do + stub_orders_request + + orders = Shipcloud::Order.all + + orders.each do |order| + expect(order).to be_a Shipcloud::Order + end + end + + it "returns a filtered list of order objects when using filter parameters" do + filter = { + "external_customer_id" => "external_customer_id", + "external_order_id" => "external_order_id", + } + + expect(Shipcloud).to receive(:request). + with(:get, "orders", filter, api_key: nil, affiliate_id: nil). + and_return(orders_array) + + Shipcloud::Order.all(filter, api_key: nil) + end + + it "uses the affiliate ID provided for the request" do + expect(Shipcloud).to receive(:request). + with(:get, "orders", {}, api_key: nil, affiliate_id: "affiliate_id"). + and_return([]) + + Shipcloud::Order.all(affiliate_id: "affiliate_id") + end + end + + describe ".find" do + it "executes a GET request to the 'orders/:id' API endpoint" do + expect(Shipcloud).to receive(:request). + with(:get, "orders/order_id", {}, api_key: nil, affiliate_id: nil). + and_return("id" => "order_id") + + Shipcloud::Order.find("order_id") + end + end + + describe ".create" do + it "executes a POST request to the 'orders' API endpoint" do + expect(Shipcloud).to receive(:request). + with(:post, "orders", valid_attributes, api_key: nil, affiliate_id: nil). + and_return("data" => {}) + + Shipcloud::Order.create(valid_attributes) + end + + it "uses the affiliate ID provided for the request" do + expect(Shipcloud).to receive(:request). + with( + :post, + "orders", + valid_attributes, + api_key: nil, + affiliate_id: "affiliate_id", + ).and_return("data" => {}) + + Shipcloud::Order.create(valid_attributes, affiliate_id: "affiliate_id") + end + end + + describe ".delete" do + it "executes a DELETE request to the 'orders/:id' API endpoint" do + expect(Shipcloud).to receive(:request). + with(:delete, "orders/123", {}, api_key: nil, affiliate_id: nil). + and_return(true) + + Shipcloud::Order.delete("123") + end + + it "does not raise an error" do + stub_request(:delete, "https://api.shipcloud.io/v1/orders/123"). + to_return(status: 204, body: "") + + expect { Shipcloud::Order.delete("123", api_key: "your-api-key") }. + to_not raise_error + end + + it "uses the affiliate ID provided for the request" do + expect(Shipcloud).to receive(:request).with( + :delete, "orders/123", {}, api_key: nil, affiliate_id: "affiliate_id" + ).and_return(true) + + Shipcloud::Order.delete("123", affiliate_id: "affiliate_id") + end + end + + def stub_orders_request(params: {}, affiliate_id: nil) + allow(Shipcloud).to receive(:request). + with(:get, "orders", params, api_key: nil, affiliate_id: affiliate_id). + and_return(orders_array) + end + + def orders_array + [ + { + id: "order_id", + external_order_id: "external_order_id", + external_customer_id: "external_customer_id", + delivery_address: { + id: "adress_id", + }, + order_line_items: [ + { + id: "order_line_item_id", + }, + ], + }, + { + id: "order_id1", + external_order_id: "external_order_id1", + external_customer_id: "external_customer_id1", + delivery_address: { + id: "adress_id1", + }, + order_line_items: [ + { + id: "order_line_item_id1", + }, + ], + }, + ] + end + + def valid_attributes + { + id: "order_id", + external_order_id: "external_order_id", + external_customer_id: "external_customer_id", + delivery_address: { + id: "adress_id", + }, + order_line_items: [ + { + id: "order_line_item_id", + }, + ], + } + end +end