From 3948b9185d732c4d0fc755bd7df8727ea3775234 Mon Sep 17 00:00:00 2001 From: Steve Ramage Date: Fri, 29 Dec 2023 08:22:13 -0800 Subject: [PATCH 1/2] Resolves #385 - Customer cart association support --- external/browser/browser.go | 3 + external/resources/resources_schema.json | 12 +- external/resources/yaml/resources.yaml | 22 +++- .../customer-cart-associations.epcc.yml | 117 ++++++++++++++++++ 4 files changed, 146 insertions(+), 8 deletions(-) create mode 100644 external/runbooks/customer-cart-associations.epcc.yml diff --git a/external/browser/browser.go b/external/browser/browser.go index 3b93670..0ea0399 100644 --- a/external/browser/browser.go +++ b/external/browser/browser.go @@ -7,6 +7,9 @@ import ( ) func OpenUrl(url string) error { + if url == "" { + return fmt.Errorf("No url available") + } switch runtime.GOOS { case "linux": exec.Command("xdg-open", url).Start() diff --git a/external/resources/resources_schema.json b/external/resources/resources_schema.json index 0b4fd31..9584275 100644 --- a/external/resources/resources_schema.json +++ b/external/resources/resources_schema.json @@ -30,12 +30,12 @@ "suppress-reset-warning": { "type": "boolean" }, - "docs": { "type": "string", "pattern": "^https://" }, + "docs": { "type": "string", "pattern": "^https?://" }, "get-collection": { "type": "object", "additionalProperties": false, "properties" : { - "docs": { "type": "string", "pattern": "^https://" }, + "docs": { "type": "string", "pattern": "^https?://" }, "url": { "type": "string" }, "content-type": { "type": "string" }, "parent_resource_value_overrides": { "type": "object" }, @@ -46,7 +46,7 @@ "get-entity": { "type": "object", "properties" : { - "docs": { "type": "string", "pattern": "^https://" }, + "docs": { "type": "string", "pattern": "^https?://" }, "url": { "type": "string" }, "content-type": { "type": "string" }, "parent_resource_value_overrides": { "type": "object" }, @@ -57,7 +57,7 @@ "update-entity": { "type": "object", "properties" : { - "docs": { "type": "string", "pattern": "^https://" }, + "docs": { "type": "string", "pattern": "^https?://" }, "url": { "type": "string" }, "content-type": { "type": "string" }, "parent_resource_value_overrides": { "type": "object" } @@ -67,7 +67,7 @@ "create-entity": { "type": "object", "properties" : { - "docs": { "type": "string", "pattern": "^https://" }, + "docs": { "type": "string", "pattern": "^https?://" }, "url": { "type": "string" }, "content-type": { "type": "string" }, "parent_resource_value_overrides": { "type": "object" } @@ -77,7 +77,7 @@ "delete-entity": { "type": "object", "properties" : { - "docs": { "type": "string", "pattern": "^https://" }, + "docs": { "type": "string", "pattern": "^https?://" }, "url": { "type": "string" }, "min": { "type": "integer" } }, diff --git a/external/resources/yaml/resources.yaml b/external/resources/yaml/resources.yaml index 8b48400..0de7673 100644 --- a/external/resources/yaml/resources.yaml +++ b/external/resources/yaml/resources.yaml @@ -219,7 +219,7 @@ carts: json-api-format: "legacy" docs: "https://documentation.elasticpath.com/commerce-cloud/docs/api/carts-and-orders/carts/index.html" get-collection: - docs: "https://documentation.elasticpath.com/commerce-cloud/docs/api/carts-and-orders/carts/associations/get-customer-carts.html" + docs: "https://elasticpath.dev/docs/commerce-cloud/carts/customer-cart-associations/get-customer-carts#get-get-all-carts" url: "/v2/carts" get-entity: docs: "https://documentation.elasticpath.com/commerce-cloud/docs/api/carts-and-orders/carts/get-a-cart.html" @@ -491,6 +491,24 @@ customers: autofill: FUNC:Email password: type: STRING +customer-cart-associations: + singular-name: customer-cart-association + json-api-type: customer-cart-relationship + json-api-format: "legacy" + no-wrapping: true + docs: "https://elasticpath.dev/docs/commerce-cloud/carts/customer-cart-associations/customer-cart-associations-overview" + delete-entity: + docs: "https://elasticpath.dev/docs/commerce-cloud/carts/customer-cart-associations/delete-an-association" + url: "/v2/carts/{carts}/relationships/customers" + create-entity: + docs: "https://elasticpath.dev/docs/commerce-cloud/carts/customer-cart-associations/create-an-association" + url: "/v2/carts/{carts}/relationships/customers" + content-type: application/json + attributes: + data[n].id: + type: RESOURCE_ID:customer + data[n].type: + type: ENUM:customer customer-addresses: singular-name: "customer-address" json-api-type: "address" @@ -797,7 +815,7 @@ entries-relationship: data.id: type: RESOURCE_ID:* data.type: - type: SINGULAR_RESOURCE_TYPE + type: JSON_API_TYPE integration-jobs: singular-name: "integration-job" json-api-type: "integration-job" diff --git a/external/runbooks/customer-cart-associations.epcc.yml b/external/runbooks/customer-cart-associations.epcc.yml new file mode 100644 index 0000000..a610d19 --- /dev/null +++ b/external/runbooks/customer-cart-associations.epcc.yml @@ -0,0 +1,117 @@ +name: "customer-cart-associations" +description: + long: "Sample commands for using customer cart association" + short: "Sample commands for using customer cart association" +actions: + create-prerequisites: + description: + short: "Create necessary prerequisites" + commands: + - epcc create pcm-hierarchy name "Major Appliances" description "Free standing appliances" slug "Major-Appliances-MA0" + - epcc create pcm-node name=Major_Appliances name "Ranges" description "All stoves and ovens" slug "Ranges-MA1" + - | + epcc create pcm-node name=Major_Appliances name "Electric Ranges" description "Electric stoves and ovens" slug "Electric-Ranges-MA2" relationships.parent.data.type node relationships.parent.data.id name=Ranges + epcc create pcm-node name=Major_Appliances name "Gas Ranges" description "Gas stoves and ovens" slug "Gas-Ranges-MA2" relationships.parent.data.type node relationships.parent.data.id name=Ranges + - epcc create pcm-product name "BestEver Electric Range" sku "BE-Electric-Range-1a1a" slug "bestever-range-1a1a" description "This electric model offers an induction heating element and convection oven." status live commodity_type physical upc_ean \"111122223333\" mpn BE-R-1111-aaaa-1a1a + - epcc create pcm-node-product name=Major_Appliances name=Electric_Ranges data[0].type product data[0].id name=BestEver_Electric_Range + - epcc create pcm-product name "BestEver Gas Range" sku "BE-Gas-Range-2b2b" slug "bestever-range-2b2b" description "This gas model includes a convection oven." status live commodity_type physical upc_ean \"222233334444\" mpn BE-R-2222-bbbb-2b2b + - epcc create pcm-node-product name=Major_Appliances name=Gas_Ranges data[0].type product data[0].id name=BestEver_Gas_Range + - epcc get -s currencies + - epcc create currency --if-alias-does-not-exist code=GBP code GBP exchange_rate 1 format £{price} decimal_point "." thousand_separator , decimal_places 2 default false enabled true + - epcc create pcm-pricebook name "Preferred Pricing" description "Catalog with pricing suitable for high-volume customers." + - | + epcc create pcm-product-price name=Preferred_Pricing currencies.USD.amount 300000 currencies.USD.includes_tax false currencies.GBP.amount 250000 currencies.GBP.includes_tax false sku BE-Electric-Range-1a1a + epcc create pcm-product-price name=Preferred_Pricing currencies.USD.amount 350000 currencies.USD.includes_tax false currencies.GBP.amount 300000 currencies.GBP.includes_tax false sku BE-Gas-Range-2b2b + - epcc create pcm-catalog name "Ranges Catalog" description "Ranges Catalog" pricebook_id name=Preferred_Pricing hierarchy_ids[0] name=Major_Appliances + - epcc create pcm-catalog-release --save-as-alias pxm-how-to-create-catalog-and-publish-release name=Ranges_Catalog + # Wait for Catalog to be Published + - epcc get pcm-catalog-release --retry-while-jq '.data.meta.release_status != "PUBLISHED"' name=Ranges_Catalog pxm-how-to-create-catalog-and-publish-release + create-customers-and-carts-with-product-items: + description: + short: "Create the customers and carts" + ignore_errors: true + commands: + - | + epcc create customer --auto-fill email "cust1@example.com" password test + epcc create customer --auto-fill email "cust2@example.com" password test + epcc create customer --auto-fill email "cust3@example.com" password test + epcc create cart name "Customer 1 Cart" id cust1_only description "Customer 1 Cart" + epcc create cart name "Customer 1&2 Shared Cart" id cust1_and_2 description "Customer 1 & 2 Cart" + epcc create cart name "No Customer Cart" id no_cust_cart description "No Customer Cart" + - epcc create customer-cart-association id=cust1_only data[0].type customer data[0].id email=cust1@example.com + - epcc create customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust1@example.com + - epcc create customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust2@example.com + - epcc create cart-product-item id=cust1_only sku sku=BE-Gas-Range-2b2b quantity 1 + - epcc create cart-product-item id=cust1_and_2 sku sku=BE-Gas-Range-2b2b quantity 2 + - epcc create cart-product-item no_cust_cart sku sku=BE-Gas-Range-2b2b quantity 3 + + create-customers-and-carts-with-custom-items: + description: + short: "Create the customers and carts" + ignore_errors: true + commands: + - | + epcc create customer --auto-fill email "cust1@example.com" password test + epcc create customer --auto-fill email "cust2@example.com" password test + epcc create customer --auto-fill email "cust3@example.com" password test + epcc create cart name "Customer 1 Cart" id cust1_only description "Customer 1 Cart" + epcc create cart name "Customer 1&2 Shared Cart" id cust1_and_2 description "Customer 1 & 2 Cart" + epcc create cart name "No Customer Cart" id no_cust_cart description "No Customer Cart" + - epcc create customer-cart-association id=cust1_only data[0].type customer data[0].id email=cust1@example.com + - epcc create customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust1@example.com + - epcc create customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust2@example.com + - epcc create cart-custom-item id=cust1_only sku sku=BE-Gas-Range-2b2b quantity 1 + - epcc create cart-custom-item id=cust1_and_2 sku sku=BE-Gas-Range-2b2b quantity 2 + - epcc create cart-custom-item no_cust_cart sku sku=BE-Gas-Range-2b2b quantity 3 + + + delete-customers-and-carts: + description: + short: "Delete all the customers and their carts" + commands: + - epcc get -s customers filter 'like(email,*@example.com)' + - | + epcc delete customer email=cust1@example.com + epcc delete customer email=cust2@example.com + epcc delete customer email=cust3@example.com + - epcc delete customer-cart-association id=cust1_only data[0].type customer data[0].id email=cust1@example.com + - epcc delete customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust1@example.com + - epcc delete customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust2@example.com + - | + epcc delete cart cust1_only + epcc delete cart cust1_and_2 + epcc delete cart no_cust_cart + + + reset: + description: + short: "Reset the store to the initial state" + ignore_errors: true + commands: + # Retrieve a bunch of data (not all), so that aliases can be populated + - | + epcc get -s pcm-products + epcc get -s pcm-catalogs + epcc get -s pcm-hierarchies + epcc get -s pcm-pricebooks + epcc get -s pcm-catalog-rules + epcc get -s customers filter 'like(email,*@example.com)' + - | + epcc get -s pcm-catalog-releases name=Ranges_Catalog + epcc get -s pcm-catalog-releases name=Ranges_Catalog_for_Special_Customers + - | + epcc delete customer email=cust1@example.com --if-alias-exists email=cust1@example.com + epcc delete customer email=cust2@example.com --if-alias-exists email=cust2@example.com + epcc delete customer email=cust3@example.com --if-alias-exists email=cust3@example.com + epcc delete currency code=GBP --if-alias-exists code=GBP + epcc delete pcm-catalog-release name=Ranges_Catalog name=Ranges_Catalog + epcc delete pcm-catalog-release name=Ranges_Catalog_for_Special_Customers name=Ranges_Catalog_for_Special_Customers + epcc delete pcm-catalog-rule name=Catalog_Rule_for_Civil_Servants --if-alias-exists name=Catalog_Rule_for_Civil_Servants + epcc delete pcm-product name=BestEver_Gas_Range --if-alias-exists name=BestEver_Gas_Range + epcc delete pcm-product name=BestEver_Electric_Range --if-alias-exists name=BestEver_Electric_Range + epcc delete pcm-hierarchy name=Major_Appliances --if-alias-exists name=Major_Appliances + epcc delete pcm-pricebook name=Preferred_Pricing --if-alias-exists name=Preferred_Pricing + epcc delete pcm-pricebook name=Loyal_Civil_Servants_Pricing --if-alias-exists name=Loyal_Civil_Servants_Pricing + - | + epcc delete pcm-catalog name=Ranges_Catalog_for_Special_Customers --if-alias-exists name=Ranges_Catalog_for_Special_Customers + epcc delete pcm-catalog name=Ranges_Catalog --if-alias-exists name=Ranges_Catalog From 281e1f8f7c9879fff694d13740552c5d37531edd Mon Sep 17 00:00:00 2001 From: Steve Ramage Date: Fri, 29 Dec 2023 09:24:37 -0800 Subject: [PATCH 2/2] Resolves #385 - Add support for customer cart associations --- .../customer-cart-associations.epcc.yml | 94 +++++++++++++++---- external/runbooks/run-all-runbooks.sh | 11 ++- 2 files changed, 85 insertions(+), 20 deletions(-) diff --git a/external/runbooks/customer-cart-associations.epcc.yml b/external/runbooks/customer-cart-associations.epcc.yml index a610d19..74448dd 100644 --- a/external/runbooks/customer-cart-associations.epcc.yml +++ b/external/runbooks/customer-cart-associations.epcc.yml @@ -29,7 +29,7 @@ actions: create-customers-and-carts-with-product-items: description: short: "Create the customers and carts" - ignore_errors: true + ignore_errors: false commands: - | epcc create customer --auto-fill email "cust1@example.com" password test @@ -48,40 +48,80 @@ actions: create-customers-and-carts-with-custom-items: description: short: "Create the customers and carts" - ignore_errors: true + ignore_errors: false commands: - | - epcc create customer --auto-fill email "cust1@example.com" password test - epcc create customer --auto-fill email "cust2@example.com" password test - epcc create customer --auto-fill email "cust3@example.com" password test - epcc create cart name "Customer 1 Cart" id cust1_only description "Customer 1 Cart" - epcc create cart name "Customer 1&2 Shared Cart" id cust1_and_2 description "Customer 1 & 2 Cart" - epcc create cart name "No Customer Cart" id no_cust_cart description "No Customer Cart" - - epcc create customer-cart-association id=cust1_only data[0].type customer data[0].id email=cust1@example.com - - epcc create customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust1@example.com - - epcc create customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust2@example.com - - epcc create cart-custom-item id=cust1_only sku sku=BE-Gas-Range-2b2b quantity 1 - - epcc create cart-custom-item id=cust1_and_2 sku sku=BE-Gas-Range-2b2b quantity 2 - - epcc create cart-custom-item no_cust_cart sku sku=BE-Gas-Range-2b2b quantity 3 + epcc create customer --auto-fill email "cust4@example.com" password test + epcc create customer --auto-fill email "cust5@example.com" password test + epcc create customer --auto-fill email "cust6@example.com" password test + epcc create cart name "Customer 4 Cart" id cust1_only description "Customer 4 Cart" + epcc create cart name "Customer 4&5 Shared Cart" id cust1_and_2 description "Customer 4 & 5 Cart" + epcc create cart name "No Customer Cart" id no_cust_cart_custom_items description "No Customer Cart (Custom Items)" + - epcc create customer-cart-association id=cust4_only data[0].type customer data[0].id email=cust4@example.com + - epcc create customer-cart-association id=cust4_and_5 data[0].type customer data[0].id email=cust4@example.com + - epcc create customer-cart-association id=cust4_and_5 data[0].type customer data[0].id email=cust5@example.com + - epcc create cart-custom-item id=cust4_only sku 123-456 quantity 1 price.amount 100000 price.includes_tax false name "Best Ever Electric Range" + - epcc create cart-custom-item id=cust4_and_5 sku 123-456 quantity 2 price.amount 100000 price.includes_tax false name "Best Ever Electric Range" + - epcc create cart-custom-item no_cust_cart_custom_items sku 123-789 quantity 3 price.amount 100000 price.includes_tax false name "Best Ever Gas Range" - delete-customers-and-carts: + delete-customer-and-carts-with-product-items: description: short: "Delete all the customers and their carts" + ignore_errors: false commands: - epcc get -s customers filter 'like(email,*@example.com)' + - epcc delete customer-cart-association id=cust1_only data[0].type customer data[0].id email=cust1@example.com + - epcc delete customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust1@example.com + - epcc delete customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust2@example.com - | epcc delete customer email=cust1@example.com epcc delete customer email=cust2@example.com epcc delete customer email=cust3@example.com - - epcc delete customer-cart-association id=cust1_only data[0].type customer data[0].id email=cust1@example.com - - epcc delete customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust1@example.com - - epcc delete customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust2@example.com - | epcc delete cart cust1_only epcc delete cart cust1_and_2 epcc delete cart no_cust_cart - + + try-and-delete-all-carts: + description: + short: "Try and delete all carts" + ignore_errors: true + commands: + - epcc get -s customers filter 'like(email,*@example.com)' + - epcc delete customer-cart-association id=cust1_only data[0].type customer data[0].id email=cust1@example.com + - epcc delete customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust1@example.com + - epcc delete customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust2@example.com + - epcc delete customer-cart-association id=cust4_only data[0].type customer data[0].id email=cust4@example.com + - epcc delete customer-cart-association id=cust4_and_5 data[0].type customer data[0].id email=cust4@example.com + - epcc delete customer-cart-association id=cust4_and_5 data[0].type customer data[0].id email=cust5@example.com + - | + epcc delete cart cust1_only + epcc delete cart cust1_and_2 + epcc delete cart no_cust_cart + epcc delete cart cust4_only + epcc delete cart cust4_and_5 + epcc delete cart no_cust_cart_custom_items + + + + delete-customer-and-carts-with-custom-items: + description: + short: "Delete all the customers and their carts" + ignore_errors: false + commands: + - epcc get -s customers filter 'like(email,*@example.com)' + - epcc delete customer-cart-association id=cust4_only data[0].type customer data[0].id email=cust4@example.com + - epcc delete customer-cart-association id=cust4_and_5 data[0].type customer data[0].id email=cust4@example.com + - epcc delete customer-cart-association id=cust4_and_5 data[0].type customer data[0].id email=cust5@example.com + - | + epcc delete customer email=cust4@example.com + epcc delete customer email=cust5@example.com + epcc delete customer email=cust6@example.com + - | + epcc delete cart cust4_only + epcc delete cart cust4_and_5 + epcc delete cart no_cust_cart_custom_items reset: description: @@ -96,6 +136,12 @@ actions: epcc get -s pcm-pricebooks epcc get -s pcm-catalog-rules epcc get -s customers filter 'like(email,*@example.com)' + - epcc delete customer-cart-association id=cust1_only data[0].type customer data[0].id email=cust1@example.com + - epcc delete customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust1@example.com + - epcc delete customer-cart-association id=cust1_and_2 data[0].type customer data[0].id email=cust2@example.com + - epcc delete customer-cart-association id=cust4_only data[0].type customer data[0].id email=cust4@example.com + - epcc delete customer-cart-association id=cust4_and_5 data[0].type customer data[0].id email=cust4@example.com + - epcc delete customer-cart-association id=cust4_and_5 data[0].type customer data[0].id email=cust5@example.com - | epcc get -s pcm-catalog-releases name=Ranges_Catalog epcc get -s pcm-catalog-releases name=Ranges_Catalog_for_Special_Customers @@ -103,6 +149,9 @@ actions: epcc delete customer email=cust1@example.com --if-alias-exists email=cust1@example.com epcc delete customer email=cust2@example.com --if-alias-exists email=cust2@example.com epcc delete customer email=cust3@example.com --if-alias-exists email=cust3@example.com + epcc delete customer email=cust4@example.com --if-alias-exists email=cust4@example.com + epcc delete customer email=cust5@example.com --if-alias-exists email=cust5@example.com + epcc delete customer email=cust6@example.com --if-alias-exists email=cust6@example.com epcc delete currency code=GBP --if-alias-exists code=GBP epcc delete pcm-catalog-release name=Ranges_Catalog name=Ranges_Catalog epcc delete pcm-catalog-release name=Ranges_Catalog_for_Special_Customers name=Ranges_Catalog_for_Special_Customers @@ -115,3 +164,10 @@ actions: - | epcc delete pcm-catalog name=Ranges_Catalog_for_Special_Customers --if-alias-exists name=Ranges_Catalog_for_Special_Customers epcc delete pcm-catalog name=Ranges_Catalog --if-alias-exists name=Ranges_Catalog + - | + epcc delete cart cust1_only + epcc delete cart cust1_and_2 + epcc delete cart no_cust_cart + epcc delete cart cust4_only + epcc delete cart cust4_and_5 + epcc delete cart no_cust_cart_custom_items diff --git a/external/runbooks/run-all-runbooks.sh b/external/runbooks/run-all-runbooks.sh index bb3cda0..cae47e1 100755 --- a/external/runbooks/run-all-runbooks.sh +++ b/external/runbooks/run-all-runbooks.sh @@ -8,6 +8,7 @@ set -x #Let's test that epcc command works after an embarrassing bug that caused it to panic :( epcc + epcc reset-store .+ echo "Starting Misc Runbook" @@ -61,7 +62,15 @@ epcc runbooks run manual-gateway-how-to capture-payment epcc runbooks run manual-gateway-how-to reset-cart epcc runbooks run manual-gateway-how-to reset - +echo "Starting Customer Cart Association Tests" +epcc reset-store .+ +epcc runbooks run customer-cart-associations try-and-delete-all-carts +epcc runbooks run customer-cart-associations create-prerequisites +epcc runbooks run customer-cart-associations create-customers-and-carts-with-product-items +epcc runbooks run customer-cart-associations delete-customer-and-carts-with-product-items +epcc runbooks run customer-cart-associations create-customers-and-carts-with-custom-items +epcc runbooks run customer-cart-associations delete-customer-and-carts-with-custom-items +epcc runbooks run customer-cart-associations reset echo "SUCCESS"