woocommerce/tests/unit-tests/order/functions.php

159 lines
4.3 KiB
PHP
Raw Normal View History

2015-03-03 11:38:05 +00:00
<?php
2015-03-06 15:32:40 +00:00
namespace WooCommerce\Tests\Order;
2015-03-03 11:38:05 +00:00
/**
2015-11-03 13:31:20 +00:00
* Class Functions.
2015-03-06 15:32:40 +00:00
* @package WooCommerce\Tests\Order
* @since 2.3
2015-03-03 11:38:05 +00:00
*/
2015-03-06 15:32:40 +00:00
class Functions extends \WC_Unit_Test_Case {
2015-03-03 11:38:05 +00:00
/**
2015-11-03 13:31:20 +00:00
* Test wc_get_order_statuses().
2015-03-03 11:38:05 +00:00
*
* @since 2.3.0
*/
public function test_wc_get_order_statuses() {
$order_statuses = apply_filters( 'wc_order_statuses', array(
'wc-pending' => _x( 'Pending Payment', 'Order status', 'woocommerce' ),
'wc-processing' => _x( 'Processing', 'Order status', 'woocommerce' ),
'wc-on-hold' => _x( 'On Hold', 'Order status', 'woocommerce' ),
'wc-completed' => _x( 'Completed', 'Order status', 'woocommerce' ),
'wc-cancelled' => _x( 'Cancelled', 'Order status', 'woocommerce' ),
'wc-refunded' => _x( 'Refunded', 'Order status', 'woocommerce' ),
'wc-failed' => _x( 'Failed', 'Order status', 'woocommerce' ),
) );
$this->assertEquals( $order_statuses, wc_get_order_statuses() );
}
/**
2015-11-03 13:31:20 +00:00
* Test wc_is_order_status().
2015-03-03 11:38:05 +00:00
*
* @since 2.3.0
*/
public function test_wc_is_order_status() {
$this->assertEquals( true, wc_is_order_status( 'wc-pending' ) );
$this->assertEquals( false, wc_is_order_status( 'wc-another-status' ) );
}
/**
2015-11-03 13:31:20 +00:00
* Test wc_get_order_status_name().
2015-03-03 11:38:05 +00:00
*
* @since 2.3.0
*/
public function test_wc_get_order_status_name() {
$this->assertEquals( _x( 'Pending Payment', 'Order status', 'woocommerce' ), wc_get_order_status_name( 'wc-pending' ) );
$this->assertEquals( _x( 'Pending Payment', 'Order status', 'woocommerce' ), wc_get_order_status_name( 'pending' ) );
2015-03-03 11:38:05 +00:00
}
/**
2015-11-03 13:31:20 +00:00
* Test wc_processing_order_count().
*
* @todo needs improvement when we have an orders helper
* @since 2.4
*/
public function test_wc_processing_order_count() {
$this->assertEquals( 0, wc_processing_order_count() );
}
/**
2015-11-03 13:31:20 +00:00
* Test wc_orders_count().
*
* @todo needs improvement when we have an orders helper
* @since 2.4
*/
public function test_wc_orders_count() {
foreach ( wc_get_order_statuses() as $status ) {
$this->assertEquals( 0, wc_orders_count( $status ) );
}
// Invalid status returns 0
$this->assertEquals( 0, wc_orders_count( 'unkown-status' ) );
}
2015-03-03 11:38:05 +00:00
/**
2015-11-03 13:31:20 +00:00
* Test wc_ship_to_billing_address_only().
2015-03-03 11:38:05 +00:00
*
* @since 2.3.0
*/
public function test_wc_ship_to_billing_address_only() {
$default = get_option( 'woocommerce_ship_to_destination' );
2015-03-03 11:47:13 +00:00
update_option( 'woocommerce_ship_to_destination', 'shipping' );
2015-03-03 11:38:05 +00:00
$this->assertEquals( false, wc_ship_to_billing_address_only() );
2015-03-03 11:47:13 +00:00
update_option( 'woocommerce_ship_to_destination', 'billing_only' );
$this->assertEquals( true, wc_ship_to_billing_address_only() );
2015-03-03 11:38:05 +00:00
2015-03-03 11:47:13 +00:00
update_option( 'woocommerce_ship_to_destination', $default );
2015-03-03 11:38:05 +00:00
}
/**
2015-11-03 13:31:20 +00:00
* Test wc_get_order().
*
* @since 2.4.0
* @group test
*/
public function test_wc_get_order() {
$order = \WC_Helper_Order::create_order();
// Assert that $order is a WC_Order object
$this->assertInstanceOf( 'WC_Order', $order );
// Assert that wc_get_order() accepts a WC_Order object
$this->assertInstanceOf( 'WC_Order', wc_get_order( $order ) );
// Assert that wc_get_order() accepts a order post id.
$this->assertInstanceOf( 'WC_Order', wc_get_order( $order->id ) );
// Assert that a non-shop_order post returns false
$post = $this->factory->post->create_and_get( array( 'post_type' => 'post' ) );
$this->assertFalse( wc_get_order( $post->ID ) );
// Assert the return when $the_order args is false
$this->assertFalse( wc_get_order( false ) );
// Assert the return when $the_order args is a random (incorrect) id.
$this->assertFalse( wc_get_order( 123456 ) );
}
/**
* Test getting an orders payment tokens
*
* @since 2.6
*/
public function test_wc_order_get_payment_tokens() {
$order = \WC_Helper_Order::create_order();
$this->assertEmpty( $order->get_payment_tokens() );
$token = \WC_Helper_Payment_Token::create_cc_token();
update_post_meta( $order->id, '_payment_tokens', array( $token->get_id() ) );
$this->assertCount( 1, $order->get_payment_tokens() );
}
/**
* Test adding a payment token to an order
*
* @since 2.6
*/
public function test_wc_order_add_payment_token() {
$order = \WC_Helper_Order::create_order();
$this->assertEmpty( $order->get_payment_tokens() );
$token = \WC_Helper_Payment_Token::create_cc_token();
$order->add_payment_token( $token );
$this->assertCount( 1, $order->get_payment_tokens() );
}
2015-03-03 11:38:05 +00:00
}