diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
| commit | 3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch) | |
| tree | a44932296ef4a9b71d5f010906253d8c53727726 /addons/website_sale/tests/test_customize.py | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/website_sale/tests/test_customize.py')
| -rw-r--r-- | addons/website_sale/tests/test_customize.py | 313 |
1 files changed, 313 insertions, 0 deletions
diff --git a/addons/website_sale/tests/test_customize.py b/addons/website_sale/tests/test_customize.py new file mode 100644 index 00000000..285a70d6 --- /dev/null +++ b/addons/website_sale/tests/test_customize.py @@ -0,0 +1,313 @@ +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +import base64 + +from odoo.addons.base.tests.common import HttpCaseWithUserDemo, HttpCaseWithUserPortal +from odoo.modules.module import get_module_resource +from odoo.tests import tagged + +@tagged('post_install', '-at_install') +class TestUi(HttpCaseWithUserDemo, HttpCaseWithUserPortal): + + def setUp(self): + super(TestUi, self).setUp() + # create a template + product_template = self.env['product.template'].create({ + 'name': 'Test Product', + 'is_published': True, + 'list_price': 750, + }) + + tax = self.env['account.tax'].create({'name': "Test tax", 'amount': 10}) + product_template.taxes_id = tax + + product_attribute = self.env['product.attribute'].create({ + 'name': 'Legs', + 'sequence': 10, + }) + product_attribute_value_1 = self.env['product.attribute.value'].create({ + 'name': 'Steel - Test', + 'attribute_id': product_attribute.id, + 'sequence': 1, + }) + product_attribute_value_2 = self.env['product.attribute.value'].create({ + 'name': 'Aluminium', + 'attribute_id': product_attribute.id, + 'sequence': 2, + }) + + # set attribute and attribute values on the template + self.env['product.template.attribute.line'].create([{ + 'attribute_id': product_attribute.id, + 'product_tmpl_id': product_template.id, + 'value_ids': [(6, 0, [product_attribute_value_1.id, product_attribute_value_2.id])] + }]) + + # set a different price on the variants to differentiate them + product_template_attribute_values = self.env['product.template.attribute.value'] \ + .search([('product_tmpl_id', '=', product_template.id)]) + + for ptav in product_template_attribute_values: + if ptav.name == "Steel - Test": + ptav.price_extra = 0 + else: + ptav.price_extra = 50.4 + + def test_01_admin_shop_customize_tour(self): + # Enable Variant Group + self.env.ref('product.group_product_variant').write({'users': [(4, self.env.ref('base.user_admin').id)]}) + self.start_tour("/", 'shop_customize', login="admin") + + def test_02_admin_shop_custom_attribute_value_tour(self): + # Make sure pricelist rule exist + self.product_attribute_1 = self.env['product.attribute'].create({ + 'name': 'Legs', + 'sequence': 10, + }) + product_attribute_value_1 = self.env['product.attribute.value'].create({ + 'name': 'Steel', + 'attribute_id': self.product_attribute_1.id, + 'sequence': 1, + }) + product_attribute_value_2 = self.env['product.attribute.value'].create({ + 'name': 'Aluminium', + 'attribute_id': self.product_attribute_1.id, + 'sequence': 2, + }) + product_attribute_2 = self.env['product.attribute'].create({ + 'name': 'Color', + 'sequence': 20, + }) + product_attribute_value_3 = self.env['product.attribute.value'].create({ + 'name': 'White', + 'attribute_id': product_attribute_2.id, + 'sequence': 1, + }) + product_attribute_value_4 = self.env['product.attribute.value'].create({ + 'name': 'Black', + 'attribute_id': product_attribute_2.id, + 'sequence': 2, + }) + + # Create product template + self.product_product_4_product_template = self.env['product.template'].create({ + 'name': 'Customizable Desk (TEST)', + 'standard_price': 500.0, + 'list_price': 750.0, + }) + + # Generate variants + self.env['product.template.attribute.line'].create([{ + 'product_tmpl_id': self.product_product_4_product_template.id, + 'attribute_id': self.product_attribute_1.id, + 'value_ids': [(4, product_attribute_value_1.id), (4, product_attribute_value_2.id)], + }, { + 'product_tmpl_id': self.product_product_4_product_template.id, + 'attribute_id': product_attribute_2.id, + 'value_ids': [(4, product_attribute_value_3.id), (4, product_attribute_value_4.id)], + + }]) + product_template = self.product_product_4_product_template + + # Add Custom Attribute + product_attribute_value_7 = self.env['product.attribute.value'].create({ + 'name': 'Custom TEST', + 'attribute_id': self.product_attribute_1.id, + 'sequence': 3, + 'is_custom': True + }) + self.product_product_4_product_template.attribute_line_ids[0].write({'value_ids': [(4, product_attribute_value_7.id)]}) + + img_path = get_module_resource('product', 'static', 'img', 'product_product_11-image.png') + img_content = base64.b64encode(open(img_path, "rb").read()) + self.product_product_11_product_template = self.env['product.template'].create({ + 'name': 'Conference Chair (TEST)', + 'website_sequence': 9999, # laule + 'image_1920': img_content, + 'list_price': 16.50, + }) + + self.env['product.template.attribute.line'].create({ + 'product_tmpl_id': self.product_product_11_product_template.id, + 'attribute_id': self.product_attribute_1.id, + 'value_ids': [(4, product_attribute_value_1.id), (4, product_attribute_value_2.id)], + }) + self.product_product_11_product_template.attribute_line_ids[0].product_template_value_ids[1].price_extra = 6.40 + + # Setup a second optional product + self.product_product_1_product_template = self.env['product.template'].create({ + 'name': 'Chair floor protection', + 'list_price': 12.0, + }) + + # fix runbot, sometimes one pricelist is chosen, sometimes the other... + pricelists = self.env['website'].get_current_website().get_current_pricelist() | self.env.ref('product.list0') + + for pricelist in pricelists: + if not pricelist.item_ids.filtered(lambda i: i.product_tmpl_id == product_template and i.price_discount == 20): + self.env['product.pricelist.item'].create({ + 'base': 'list_price', + 'applied_on': '1_product', + 'pricelist_id': pricelist.id, + 'product_tmpl_id': product_template.id, + 'price_discount': 20, + 'min_quantity': 2, + 'compute_price': 'formula', + }) + + pricelist.discount_policy = 'without_discount' + + self.start_tour("/", 'shop_custom_attribute_value', login="admin") + + def test_03_public_tour_shop_dynamic_variants(self): + """ The goal of this test is to make sure product variants with dynamic + attributes can be created by the public user (when being added to cart). + """ + + # create the attribute + product_attribute = self.env['product.attribute'].create({ + 'name': "Dynamic Attribute", + 'create_variant': 'dynamic', + }) + + # create the attribute values + product_attribute_values = self.env['product.attribute.value'].create([{ + 'name': "Dynamic Value 1", + 'attribute_id': product_attribute.id, + 'sequence': 1, + }, { + 'name': "Dynamic Value 2", + 'attribute_id': product_attribute.id, + 'sequence': 2, + }]) + + # create the template + product_template = self.env['product.template'].create({ + 'name': 'Dynamic Product', + 'website_published': True, + 'list_price': 0, + }) + + # set attribute and attribute values on the template + self.env['product.template.attribute.line'].create([{ + 'attribute_id': product_attribute.id, + 'product_tmpl_id': product_template.id, + 'value_ids': [(6, 0, product_attribute_values.ids)] + }]) + + # set a different price on the variants to differentiate them + product_template_attribute_values = self.env['product.template.attribute.value'] \ + .search([('product_tmpl_id', '=', product_template.id)]) + + for ptav in product_template_attribute_values: + if ptav.name == "Dynamic Value 1": + ptav.price_extra = 10 + else: + # 0 to not bother with the pricelist of the public user + ptav.price_extra = 0 + + self.start_tour("/", 'tour_shop_dynamic_variants') + + def test_04_portal_tour_deleted_archived_variants(self): + """The goal of this test is to make sure deleted and archived variants + are shown as impossible combinations. + + Using "portal" to have various users in the tests. + """ + + # create the attribute + product_attribute = self.env['product.attribute'].create({ + 'name': "My Attribute", + 'create_variant': 'always', + }) + + # create the attribute values + product_attribute_values = self.env['product.attribute.value'].create([{ + 'name': "My Value 1", + 'attribute_id': product_attribute.id, + 'sequence': 1, + }, { + 'name': "My Value 2", + 'attribute_id': product_attribute.id, + 'sequence': 2, + }, { + 'name': "My Value 3", + 'attribute_id': product_attribute.id, + 'sequence': 3, + }]) + + # create the template + product_template = self.env['product.template'].create({ + 'name': 'Test Product 2', + 'is_published': True, + }) + + # set attribute and attribute values on the template + self.env['product.template.attribute.line'].create([{ + 'attribute_id': product_attribute.id, + 'product_tmpl_id': product_template.id, + 'value_ids': [(6, 0, product_attribute_values.ids)] + }]) + + # set a different price on the variants to differentiate them + product_template_attribute_values = self.env['product.template.attribute.value'] \ + .search([('product_tmpl_id', '=', product_template.id)]) + + product_template_attribute_values[0].price_extra = 10 + product_template_attribute_values[1].price_extra = 20 + product_template_attribute_values[2].price_extra = 30 + + # archive first combination (first variant) + product_template.product_variant_ids[0].active = False + # delete second combination (which is now first variant since cache has been cleared) + product_template.product_variant_ids[0].unlink() + + self.start_tour("/", 'tour_shop_deleted_archived_variants', login="portal") + + def test_05_demo_tour_no_variant_attribute(self): + """The goal of this test is to make sure attributes no_variant are + correctly added to cart. + + Using "demo" to have various users in the tests. + """ + + # create the attribute + product_attribute_no_variant = self.env['product.attribute'].create({ + 'name': "No Variant Attribute", + 'create_variant': 'no_variant', + }) + + # create the attribute value + product_attribute_value_no_variant = self.env['product.attribute.value'].create({ + 'name': "No Variant Value", + 'attribute_id': product_attribute_no_variant.id, + }) + + # create the template + product_template = self.env['product.template'].create({ + 'name': 'Test Product 3', + 'website_published': True, + }) + + # set attribute and attribute value on the template + ptal = self.env['product.template.attribute.line'].create([{ + 'attribute_id': product_attribute_no_variant.id, + 'product_tmpl_id': product_template.id, + 'value_ids': [(6, 0, product_attribute_value_no_variant.ids)] + }]) + + # set a price on the value + ptal.product_template_value_ids.price_extra = 10 + + self.start_tour("/", 'tour_shop_no_variant_attribute', login="demo") + + def test_06_admin_list_view_b2c(self): + self.env.ref('product.group_product_variant').write({'users': [(4, self.env.ref('base.user_admin').id)]}) + + # activate b2c + config = self.env['res.config.settings'].create({}) + config.show_line_subtotals_tax_selection = "tax_included" + config._onchange_sale_tax() + config.execute() + + self.start_tour("/", 'shop_list_view_b2c', login="admin") |
