woocommerce / woocommerce-square

Square POS and Payments Integration
https://woo.com/products/square
Other
11 stars 7 forks source link

Checkout stalls on subscription purchase with $0 upfront cost #10

Open WillBrubaker opened 1 year ago

WillBrubaker commented 1 year ago

Describe the bug

If a subscription has a $0 initial cost and Square is used for payment, checkout will hang.

Was: https://github.com/woocommerce/woocommerce-gift-cards/issues/611

To reproduce

  1. a 100% coupon exists
  2. a card is saved with Square
  3. The cart has only a subscription product
  4. Apply the coupon to reduce the initial cost to $0
  5. Attempt to pay with the saved card with Square

Screenshots

0qhY21.png

Expected behavior

To be able to checkout.

Environment (please complete the following information):

Additional details

System status ``` ### WordPress Environment ### WordPress address (URL): https://thisweekslunch.com Site address (URL): https://thisweekslunch.com WC Version: 7.1.0 REST API Version: ✔ 7.1.0 WC Blocks Version: ✔ 8.7.5 Action Scheduler Version: ✔ 3.4.0 Log Directory Writable: ✔ WP Version: ✔ 6.1.1 WP Multisite: – WP Memory Limit: 1 GB WP Debug Mode: – WP Cron: ✔ Language: en_CA External object cache: ✔ ### Server Environment ### Server Info: Apache PHP Version: 7.4.30 PHP Post Max Size: 200 MB PHP Time Limit: 600 PHP Max Input Vars: 10000 cURL Version: 7.80.0 OpenSSL/1.1.1q SUHOSIN Installed: – MySQL Version: 5.7.26-29-log Max Upload Size: 200 MB Default Timezone is UTC: ✔ fsockopen/cURL: ✔ SoapClient: ✔ DOMDocument: ✔ GZip: ✔ Multibyte String: ✔ Remote Post: ✔ Remote Get: ✔ ### Database ### WC Database Version: 7.1.0 WC Database Prefix: wp_gzddnhby2t_ Total Database Size: 36.48MB Database Data Size: 25.45MB Database Index Size: 11.03MB wp_gzddnhby2t_woocommerce_sessions: Data: 1.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_woocommerce_api_keys: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_woocommerce_attribute_taxonomies: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_woocommerce_downloadable_product_permissions: Data: 0.02MB + Index: 0.06MB + Engine InnoDB wp_gzddnhby2t_woocommerce_order_items: Data: 0.08MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_woocommerce_order_itemmeta: Data: 0.44MB + Index: 0.39MB + Engine InnoDB wp_gzddnhby2t_woocommerce_tax_rates: Data: 0.02MB + Index: 0.06MB + Engine InnoDB wp_gzddnhby2t_woocommerce_tax_rate_locations: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_woocommerce_shipping_zones: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_woocommerce_shipping_zone_locations: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_woocommerce_shipping_zone_methods: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_woocommerce_payment_tokens: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_woocommerce_payment_tokenmeta: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_woocommerce_log: Data: 0.02MB + Index: 0.02MB + Engine InnoDB godaddy_mwc_cart_recovery_emails_opt_outs: Data: 0.02MB + Index: 0.02MB + Engine InnoDB godaddy_mwc_checkout: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_acm_cron_logs: Data: 0.14MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_actionscheduler_actions: Data: 2.02MB + Index: 1.19MB + Engine InnoDB wp_gzddnhby2t_actionscheduler_claims: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_actionscheduler_groups: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_actionscheduler_logs: Data: 1.11MB + Index: 0.69MB + Engine InnoDB wp_gzddnhby2t_afwc_campaigns: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_afwc_commission_plans: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_afwc_hits: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_afwc_payouts: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_afwc_payout_orders: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_afwc_referrals: Data: 0.02MB + Index: 0.08MB + Engine InnoDB wp_gzddnhby2t_automatewoo_abandoned_carts: Data: 0.05MB + Index: 0.08MB + Engine InnoDB wp_gzddnhby2t_automatewoo_customers: Data: 0.02MB + Index: 0.09MB + Engine InnoDB wp_gzddnhby2t_automatewoo_customer_meta: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_automatewoo_events: Data: 0.02MB + Index: 0.05MB + Engine InnoDB wp_gzddnhby2t_automatewoo_guests: Data: 0.02MB + Index: 0.06MB + Engine InnoDB wp_gzddnhby2t_automatewoo_guest_meta: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_automatewoo_logs: Data: 0.06MB + Index: 0.05MB + Engine InnoDB wp_gzddnhby2t_automatewoo_log_meta: Data: 0.14MB + Index: 0.16MB + Engine InnoDB wp_gzddnhby2t_automatewoo_queue: Data: 0.02MB + Index: 0.05MB + Engine InnoDB wp_gzddnhby2t_automatewoo_queue_meta: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_automatewoo_referrals: Data: 0.02MB + Index: 0.08MB + Engine InnoDB wp_gzddnhby2t_automatewoo_referral_advocate_keys: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_automatewoo_referral_invites: Data: 0.02MB + Index: 0.05MB + Engine InnoDB wp_gzddnhby2t_bwg_album: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_bwg_album_gallery: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_bwg_file_paths: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_bwg_gallery: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_bwg_image: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_bwg_image_comment: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_bwg_image_rate: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_bwg_image_tag: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_bwg_shortcode: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_bwg_theme: Data: 0.08MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_ce4wp_abandoned_checkout: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_ce4wp_contacts: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_commentmeta: Data: 0.08MB + Index: 0.09MB + Engine InnoDB wp_gzddnhby2t_comments: Data: 1.52MB + Index: 0.88MB + Engine InnoDB wp_gzddnhby2t_gf_draft_submissions: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_gf_entry: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_gf_entry_meta: Data: 0.02MB + Index: 0.05MB + Engine InnoDB wp_gzddnhby2t_gf_entry_notes: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_gf_form: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_gf_form_meta: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_gf_form_revisions: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_gf_form_view: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_links: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_ms_snippets: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_mystickymenu_contact_lists: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_options: Data: 7.22MB + Index: 0.14MB + Engine InnoDB wp_gzddnhby2t_postmeta: Data: 3.52MB + Index: 4.00MB + Engine InnoDB wp_gzddnhby2t_posts: Data: 4.14MB + Index: 0.42MB + Engine InnoDB wp_gzddnhby2t_snippets: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_termmeta: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_terms: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_term_relationships: Data: 0.05MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_term_taxonomy: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_usermeta: Data: 0.25MB + Index: 0.17MB + Engine InnoDB wp_gzddnhby2t_users: Data: 0.02MB + Index: 0.05MB + Engine InnoDB wp_gzddnhby2t_wcs_payment_retries: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_wc_admin_notes: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_wc_admin_note_actions: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_wc_category_lookup: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_wc_customer_lookup: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_wc_download_log: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_wc_order_coupon_lookup: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_wc_order_product_lookup: Data: 0.06MB + Index: 0.06MB + Engine InnoDB wp_gzddnhby2t_wc_order_stats: Data: 0.11MB + Index: 0.08MB + Engine InnoDB wp_gzddnhby2t_wc_order_tax_lookup: Data: 0.06MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_wc_points_rewards_user_points: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_wc_points_rewards_user_points_log: Data: 0.05MB + Index: 0.05MB + Engine InnoDB wp_gzddnhby2t_wc_product_attributes_lookup: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_wc_product_download_directories: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_wc_product_meta_lookup: Data: 0.02MB + Index: 0.09MB + Engine InnoDB wp_gzddnhby2t_wc_rate_limits: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_wc_reserved_stock: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_wc_tax_rate_classes: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_wc_webhooks: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_woocommerce_exported_csv_items: Data: 1.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_woocommerce_gc_activity: Data: 0.02MB + Index: 0.06MB + Engine InnoDB wp_gzddnhby2t_woocommerce_gc_cards: Data: 0.02MB + Index: 0.06MB + Engine InnoDB wp_gzddnhby2t_woocommerce_gc_cardsmeta: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_woocommerce_square_customers: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_wpfm_backup: Data: 0.02MB + Index: 0.00MB + Engine InnoDB wp_gzddnhby2t_yoast_indexable: Data: 0.52MB + Index: 0.41MB + Engine InnoDB wp_gzddnhby2t_yoast_indexable_hierarchy: Data: 0.06MB + Index: 0.05MB + Engine InnoDB wp_gzddnhby2t_yoast_migrations: Data: 0.02MB + Index: 0.02MB + Engine InnoDB wp_gzddnhby2t_yoast_primary_term: Data: 0.02MB + Index: 0.03MB + Engine InnoDB wp_gzddnhby2t_yoast_seo_links: Data: 0.05MB + Index: 0.03MB + Engine InnoDB ### Post Type Counts ### acf-field: 147 acf-field-group: 10 attachment: 320 aw_workflow: 10 bwg_gallery: 2 bwg_share: 1 custom_css: 2 customize_changeset: 5 fme_qifw_woocomerce: 1 nav_menu_item: 43 page: 31 post: 13 product: 157 revision: 512 shop_coupon: 35 shop_order: 1018 shop_order_refund: 10 shop_subscription: 110 sitesetting: 1 wc_membership_plan: 1 wc_user_membership: 67 wpcf7_contact_form: 1 ### Security ### Secure connection (HTTPS): ✔ Hide errors from visitors: ✔ ### Active Plugins (39) ### Gravity Forms: by Gravity Forms – 2.4.22 10WEB manager: by 10Web – 1.5.6 Advanced Custom Fields: Gallery Field: by Elliot Condon – 2.1.0 Advanced Custom Fields: Repeater Field: by Elliot Condon – 2.1.0 Advanced Cron Manager PRO: by BracketSpace – 2.5.3 Advanced Cron Manager: by BracketSpace – 2.4.2 Advanced Custom Fields: Font Awesome: by Matt Keys – 4.0.4 Advanced Custom Fields: by WP Engine – 6.0.4 Affiliate For WooCommerce: by StoreApps – 5.9.0 Akismet Anti-Spam: by Automattic – 5.0.1 AutomateWoo - Refer A Friend Add-on: by WooCommerce – 2.6.14 AutomateWoo: by WooCommerce – 5.6.0 Classic Editor: by WordPress Contributors – 1.6.2 Classic Widgets: by WordPress Contributors – 0.3 Code Snippets: by Code Snippets Pro – 3.2.1 Contact Form 7: by Takayuki Miyoshi – 5.6.4 Custom Post Type UI: by WebDevStudios – 1.13.1 GA Google Analytics: by Jeff Starr – 20221016 Hide Categories Or Products On Shop Page: by Kaushik Nakrani – 1.0.3 myStickymenu: by Premio – 2.6.1 Photo Gallery: by Photo Gallery Team – 2.6.3 Quantity Buttons for WooCommerce: by FME Addons – 1.0.5 Self-service Dashboard for WooCommerce Subscriptions: by eCommerce Tools – 2.0.0 Sticky Posts - Switch: by Markus Wiesenhofer – 2.1.3 Sucuri Security - Auditing, Malware Scanner and Hardening: by Sucuri Inc. – 1.8.35 WooCommerce Customer/Order/Coupon Export: by SkyVerge – 5.3.5 WooCommerce Gift Cards: by WooCommerce – 1.13.1 WooCommerce Mark Orders as Complete: by Patrick Rauland – 1.0.0 WooCommerce Memberships: by SkyVerge – 1.23.1 WooCommerce Payments: by Automattic – 5.0.3 WooCommerce Points and Rewards: by WooCommerce – 1.7.20 WooCommerce Protected Categories: by Barn2 Plugins – 2.6.1 WooCommerce Square: by WooCommerce – 3.3.0 WooCommerce Subscriptions: by WooCommerce – 4.6.0 WooCommerce: by Automattic – 7.1.0 Yoast SEO: by Team Yoast – 19.10 WP File Manager: by mndpsingh287 – 7.1.6 XT Floating Cart for WooCommerce Pro: by XplodedThemes – 2.6.9 YITH WooCommerce Quick View Premium: by YITH – 1.22.0 ### Inactive Plugins (4) ### Add Quantity Field on Shop Page for WooCommerce: by Tanvirul Haque – 1.0.12 Quantity Plus Minus Button for WooCommerce by CodeAstrology: by CodeAstrology Team – 1.1.4 WooCommerce Quick View: by WooCommerce – 1.6.0 XT Floating Cart for WooCommerce: by XplodedThemes – 2.6.9 ### Dropin Plugins (2) ### db-error.php: db-error.php object-cache.php: object-cache.php ### Must Use Plugins (2) ### Object Cache Pro (MU): by Rhubarb Group – 1.16.4 System Plugin: by – 4.52.0 ### Settings ### API Enabled: – Force SSL: – Currency: CAD ($) Currency Position: left Thousand Separator: , Decimal Separator: . Number of Decimals: 2 Taxonomies: Product Types: external (external) grouped (grouped) simple (simple) subscription (subscription) variable (variable) Taxonomies: Product Visibility: exclude-from-catalog (exclude-from-catalog) exclude-from-search (exclude-from-search) featured (featured) outofstock (outofstock) rated-1 (rated-1) rated-2 (rated-2) rated-3 (rated-3) rated-4 (rated-4) rated-5 (rated-5) Connected to WooCommerce.com: ✔ Enforce Approved Product Download Directories: – ### WC Pages ### Shop base: woocommerce/woocommerce-square-private#25 - /shop/ Cart: woocommerce/woocommerce-square-private#27 - /my-cart/ Checkout: woocommerce/woocommerce-square-private#28 - /checkout/ My account: woocommerce/woocommerce-square-private#26 - /my-account/ Terms and conditions: #1586 - /terms/ ### Theme ### Name: This weeks lunch Version: 2021 Author URL: Child Theme: ❌ – If you are modifying WooCommerce on a parent theme that you did not build personally we recommend using a child theme. See: How to create a child theme WooCommerce Support: ✔ ### Templates ### Overrides: lunch/woocommerce/archive-product.php lunch/woocommerce/checkout/thankyou.php lunch/woocommerce/content-product.php lunch/woocommerce/content-single-product.php lunch/woocommerce/loop/add-to-cart.php lunch/woocommerce/loop/loop-end.php lunch/woocommerce/loop/loop-start.php lunch/woocommerce/loop/price.php ### Memberships ### Restriction mode:: Redirect to page Public content:: – Excluded from discounts:: – Membership plans:: 1 This Weeks Menu Subscibers:: Members: 67Access method: Product(s) purchaseAccess length: Unlimited Subscription: OptionalInstallment plan: No ### Subscriptions ### WCS_DEBUG: ✔ No Subscriptions Mode: ✔ Live Subscriptions Live URL: https://thisweekslunch.com Subscription Statuses: wc-active: 19 wc-pending-cancel: 1 wc-on-hold: 34 wc-cancelled: 56 WooCommerce Account Connected: ✔ Yes Active Product Key: ❌ No Custom Retry Rules: ✔ No Custom Retry Rule Class: ✔ No Custom Raw Retry Rule: ✔ No Custom Retry Rule: ✔ No Retries Migration Status: ✔ Completed Report Cache Enabled: ✔ Yes Cache Update Failures: ✔ 0 failure ### Store Setup ### Country / State: Canada — British Columbia ### Subscriptions by Payment Gateway ### Square: wc-active: 19 wc-cancelled: 50 wc-on-hold: 26 wc-pending-cancel: 1 ### Payment Gateway Support ### Square: products card_types customer_decline_messages payment_form authorization charge charge-virtual capture_charge refunds voids customer_id tokenization add_payment_method token_editor subscriptions subscription_suspension subscription_cancellation subscription_reactivation subscription_amount_changes subscription_date_changes multiple_subscriptions subscription_payment_method_change_customer subscription_payment_method_change_admin ### Gift Cards ### Database Version: 1.13.1 Loopback Test: ✔ Task Queueing Test: ✔ ### Square ### Environment: Production Tokenization Enabled: Debug Mode: Off ### Admin ### Enabled Features: activity-panels analytics coupons customer-effort-score-tracks experimental-products-task experimental-import-products-task experimental-fashion-sample-products shipping-smart-defaults shipping-setting-tour homescreen marketing multichannel-marketing mobile-app-banner navigation onboarding onboarding-tasks remote-inbox-notifications remote-free-extensions payment-gateway-suggestions shipping-label-banner subscriptions store-alerts transient-notices woo-mobile-welcome wc-pay-promotion wc-pay-welcome-page Disabled Features: minified-js new-product-management-experience settings Daily Cron: ✔ Next scheduled: 2022-11-16 03:13:33 -08:00 Options: ✔ Notes: 34 Onboarding: completed ### WooCommerce Payments ### Version: 5.0.3 Connected to WPCOM: No Blog ID: - Account ID: - ### WooCommerce Customer/Order/Coupon Export ### Automated exports: 0 Custom formats: 0 Next export: Not scheduled ### Action Scheduler ### Canceled: 11 Oldest: 2022-10-31 12:19:26 +0000 Newest: 2022-11-14 14:15:20 +0000 Complete: 3,348 Oldest: 2022-10-16 05:13:50 +0000 Newest: 2022-11-15 23:12:14 +0000 Failed: 205 Oldest: 2022-05-09 04:41:07 +0000 Newest: 2022-10-10 11:41:03 +0000 Pending: 24 Oldest: 2022-11-16 00:38:47 +0000 Newest: 2022-11-28 12:00:59 +0000 ### Status report information ### Generated at: 2022-11-15 15:13:48 -08:00 ```
madisoncmiller commented 1 year ago

Here is the ticket for reference ^ 5715079-zen