[Erp5-report] r19558 - /erp5/trunk/products/ERP5/tests/testERP5Commerce.py

nobody at svn.erp5.org nobody at svn.erp5.org
Thu Feb 28 15:17:44 CET 2008


Author: ivan
Date: Thu Feb 28 15:17:43 2008
New Revision: 19558

URL: http://svn.erp5.org?rev=19558&view=rev
Log:
Moved from erp5_commerce bt5.

Added:
    erp5/trunk/products/ERP5/tests/testERP5Commerce.py

Added: erp5/trunk/products/ERP5/tests/testERP5Commerce.py
URL: http://svn.erp5.org/erp5/trunk/products/ERP5/tests/testERP5Commerce.py?rev=19558&view=auto
==============================================================================
--- erp5/trunk/products/ERP5/tests/testERP5Commerce.py (added)
+++ erp5/trunk/products/ERP5/tests/testERP5Commerce.py Thu Feb 28 15:17:43 2008
@@ -1,0 +1,290 @@
+##############################################################################
+#
+# Copyright (c) 2005 Nexedi SARL and Contributors. All Rights Reserved.
+#                     Ivan Tyagov <ivan at nexedi.com>
+#
+# WARNING: This program as such is intended to be used by professional
+# programmers who take the whole responsability of assessing all potential
+# consequences resulting from its eventual inadequacies and bugs
+# End users who are looking for a ready-to-use solution with commercial
+# garantees and support are strongly adviced to contract a Free Software
+# Service Company
+#
+# This program is Free Software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+#
+##############################################################################
+
+import os, sys
+if __name__ == '__main__':
+  execfile(os.path.join(sys.path[0], 'framework.py'))
+
+# Needed in order to have a log file inside the current folder
+os.environ['EVENT_LOG_FILE'] = os.path.join(os.getcwd(), 'zLOG.log')
+os.environ['EVENT_LOG_SEVERITY'] = '-300'
+
+from Testing import ZopeTestCase
+from Products.ERP5Type.tests.ERP5TypeTestCase import ERP5TypeTestCase
+from AccessControl.SecurityManagement import newSecurityManager
+from Products.CMFCore.permissions import *
+from zLOG import LOG
+
+SESSION_ID = "12345678"
+
+class TestCommerce(ERP5TypeTestCase):
+
+  run_all_test = 1
+  
+  def getTitle(self):
+    return "E-Commerce System"
+  
+  def afterSetUp(self):
+    self.login()
+    portal = self.getPortal()
+    # create default currency (EUR)
+    currency = portal.currency_module.newContent(portal_type = 'Currency', id = '1')
+    currency.setTitle('EUR')
+    currency.setReference('EUR')
+    currency.setBaseUnitQuantity(0.01)
+    # create product, set price & currency
+    product = portal.product_module.newContent(portal_type = 'Product', id = '1')
+    product.setSupplyLinePriceCurrency(currency.getRelativeUrl())
+    product.setBasePrice(10.0)
+    # create second product, set price & currency
+    product = portal.product_module.newContent(portal_type = 'Product', id = '2')
+    product.setSupplyLinePriceCurrency(currency.getRelativeUrl())
+    product.setBasePrice(20.0)
+    # create shipping which is actually a product
+    shipping = portal.product_module.newContent(portal_type = 'Product', id = '3')
+    shipping.setSupplyLinePriceCurrency(currency.getRelativeUrl())
+    shipping.setBasePrice(10.0)
+    shipping.setProductLine('shipping')
+    
+  def login(self, quiet=0, run=run_all_test):
+    uf = self.getPortal().acl_users
+    uf._doAddUser('ivan', '', ['Manager'], [])
+    uf._doAddUser('ERP5TypeTestCase', '', ['Manager'], [])
+    user = uf.getUserById('ivan').__of__(uf)
+    newSecurityManager(None, user)
+
+ 
+  def getBusinessTemplateList(self):
+    """
+      Return the list of required business templates.
+    """
+    return ('erp5_base', 'erp5_web', 
+            'erp5_trade', 'erp5_pdm', 'erp5_commerce',)
+            
+  def getDefaultProduct(self, id = '1'):
+    """ 
+      Get default product.
+    """
+    return self.getPortal().product_module[id]
+    
+  def test_01_AddResourceToShoppingCart(self, quiet=0, run=run_all_test):
+    """ 
+       Test adding an arbitrary resources to shopping cart.
+    """
+    if not run:
+      return
+    if not quiet:
+      message = '\nCheck adding product to shopping cart'
+      ZopeTestCase._print(message)
+      LOG('Testing... ', 0, message)
+    portal = self.getPortal()
+    request = self.app.REQUEST
+    default_product = self.getDefaultProduct()
+    
+    # set 'session_id' to simulate browser (cookie) environment 
+    request.set('session_id', SESSION_ID)
+
+    # add product to shopping cart
+    portal.Resource_addToShoppingCart(default_product, 1)
+    shoppping_cart_items =  portal.SaleOrder_getShoppingCartItemList()
+    self.assertEquals(1, len(shoppping_cart_items))
+    self.assertEquals(1, shoppping_cart_items[0].getQuantity())
+    self.assertEquals(shoppping_cart_items[0].getResource(), \
+                      default_product.getRelativeUrl())
+    
+  def test_02_AddSameResourceToShoppingCart(self, quiet=0, run=run_all_test):
+    """ 
+       Test adding same resource to shopping cart.
+    """
+    if not run:
+      return
+    if not quiet:
+      message = '\nCheck adding same product to shopping cart'
+      ZopeTestCase._print(message)
+      LOG('Testing... ', 0, message)
+    portal = self.getPortal()
+    request = self.app.REQUEST
+    default_product = self.getDefaultProduct()
+    request.set('session_id', SESSION_ID)
+    
+    # add in two speps same product and check that we do not create
+    # new Sale Order Line but just increase quantity on existing one
+    portal.Resource_addToShoppingCart(default_product, 1)
+    portal.Resource_addToShoppingCart(default_product, 1)
+    shoppping_cart_items =  portal.SaleOrder_getShoppingCartItemList()
+    self.assertEquals(1, len(shoppping_cart_items))
+    self.assertEquals(2, shoppping_cart_items[0].getQuantity())
+    self.assertEquals(shoppping_cart_items[0].getResource(), \
+                      default_product.getRelativeUrl())
+
+  def test_03_AddDifferentResourceToShoppingCart(self, quiet=0, run=run_all_test):
+    """ 
+       Test adding different resource to shopping cart.
+    """
+    if not run:
+      return
+    if not quiet:
+      message = '\nCheck adding different product to shopping cart'
+      ZopeTestCase._print(message)
+      LOG('Testing... ', 0, message)
+    portal = self.getPortal()
+    request = self.app.REQUEST
+    default_product = self.getDefaultProduct()
+    another_product = self.getDefaultProduct(id = '2')
+    request.set('session_id', SESSION_ID)
+    
+    # add second diff product and check that we create new Sale Order Line 
+    portal.Resource_addToShoppingCart(default_product, 2)
+    portal.Resource_addToShoppingCart(another_product, 1)
+    shoppping_cart_items =  portal.SaleOrder_getShoppingCartItemList()
+    self.assertEquals(2, len(shoppping_cart_items))
+    self.assertEquals(2, shoppping_cart_items[0].getQuantity())
+    self.assertEquals(1, shoppping_cart_items[1].getQuantity())
+    self.assertEquals(shoppping_cart_items[0].getResource(), \
+                      default_product.getRelativeUrl())
+    self.assertEquals(shoppping_cart_items[1].getResource(), \
+                      another_product.getRelativeUrl())
+                      
+                      
+  def test_04_CalculateTotaShoppingCartPrice(self, quiet=0, run=run_all_test):
+    """ 
+       Test calculation shopping cart's total price.
+    """
+    if not run:
+      return
+    if not quiet:
+      message = '\nTest calculation shopping cart total price'
+      ZopeTestCase._print(message)
+      LOG('Testing... ', 0, message)
+    portal = self.getPortal()
+    request = self.app.REQUEST
+    default_product = self.getDefaultProduct()
+    another_product = self.getDefaultProduct(id = '2')
+    request.set('session_id', SESSION_ID)
+    
+    portal.Resource_addToShoppingCart(default_product, 2)
+    portal.Resource_addToShoppingCart(another_product, 1)
+    shopping_cart = portal.SaleOrder_getShoppingCart()
+    self.assertEquals(40.0, \
+         float(shopping_cart.SaleOrder_getShoppingCartTotalPrice()))
+    # include taxes (by default it's 20%)
+    self.assertEquals(40.0*1.20, \
+       float(shopping_cart.SaleOrder_getShoppingCartTotalPrice(include_shipping = True,
+                                                                 include_taxes = True)))
+    # no shipping selected yet so price should be the same
+    self.assertEquals(40.0, \
+       float(shopping_cart.SaleOrder_getShoppingCartTotalPrice(include_shipping = True)))
+    # add shipping
+    shipping = self.getDefaultProduct('3')
+    portal.SaleOrder_editShoppingCart(field_my_shipping_method=shipping.getRelativeUrl())
+    # test price calculation only with shipping
+    self.assertEquals(40.0 + 10.0, \
+       float(shopping_cart.SaleOrder_getShoppingCartTotalPrice(include_shipping = True)))
+    # test price calculation shipping and taxes
+    self.assertEquals((40.0 + 10.0)*1.20, \
+         float(shopping_cart.SaleOrder_getShoppingCartTotalPrice(include_shipping = True,
+                                                                 include_taxes = True)))
+                                                                 
+  def test_05_TestUpdateShoppingCart(self, quiet=0, run=run_all_test):
+    """ 
+       Test update of shopping cart.
+    """
+    if not run:
+      return
+    if not quiet:
+      message = '\nTest update of shopping cart'
+      ZopeTestCase._print(message)
+      LOG('Testing... ', 0, message)
+    portal = self.getPortal()
+    request = self.app.REQUEST
+    
+    default_product = self.getDefaultProduct()
+    another_product = self.getDefaultProduct(id = '2')
+    shipping = self.getDefaultProduct('3')
+    request.set('session_id', SESSION_ID)
+    portal.Resource_addToShoppingCart(default_product, quantity=1)
+    portal.Resource_addToShoppingCart(another_product, quantity=1)
+
+    shopping_cart = portal.SaleOrder_getShoppingCart()
+    portal.SaleOrder_editShoppingCart(field_my_shipping_method=shipping.getRelativeUrl())
+    
+    # increase shopping item number
+    portal.SaleOrder_editShoppingCart((2, 1,))
+    
+    # test price calculation without shipping and without taxes
+    self.assertEquals((10.0*2 + 20.0*1)*1.0, \
+       float(shopping_cart.SaleOrder_getShoppingCartTotalPrice(include_shipping = False,
+                                                               include_taxes = False)))
+    # test price calculation with shipping and without taxes
+    self.assertEquals((10.0*2  + 20.0*1 + 10.0)*1.0, \
+         float(shopping_cart.SaleOrder_getShoppingCartTotalPrice(include_shipping = True,
+                                                                 include_taxes = False)))
+    # test price calculation with shipping and with taxes
+    self.assertEquals((10.0*2 + 20.0*1 + 10.0)*1.20, \
+         float(shopping_cart.SaleOrder_getShoppingCartTotalPrice(include_shipping = True,
+                                                                 include_taxes = True)))
+    
+    # delete shopping item
+    portal.SaleOrder_deleteShoppingCartItem('1')
+    self.assertEquals(1, \
+                      len(portal.SaleOrder_getShoppingCartItemList()))
+                       
+    portal.SaleOrder_deleteShoppingCartItem('2')
+    self.assertEquals(0, \
+                      len(portal.SaleOrder_getShoppingCartItemList()))
+    self.assertEquals(0.0, \
+                      float(shopping_cart.SaleOrder_getShoppingCartTotalPrice()))
+
+  def test_06_TestClearShoppingCart(self, quiet=0, run=run_all_test):
+    """ 
+       Test update of shopping cart.
+    """
+    if not run:
+      return
+    if not quiet:
+      message = '\nTest clear shopping cart'
+      ZopeTestCase._print(message)
+      LOG('Testing... ', 0, message)
+    portal = self.getPortal()
+    request = self.app.REQUEST
+    default_product = self.getDefaultProduct()
+    request.set('session_id', SESSION_ID)
+    shopping_cart = portal.SaleOrder_getShoppingCart(action='reset')
+    self.assertEquals(0, \
+                      len(portal.SaleOrder_getShoppingCartItemList()))
+    
+
+if __name__ == '__main__':
+    framework()
+else:
+    import unittest
+    def test_suite():
+        suite = unittest.TestSuite()
+        suite.addTest(unittest.makeSuite(TestCommerce))
+        return suite
+




More information about the Erp5-report mailing list