From b61853c4b97104184b5aa8790739e6b8d3c693e4 Mon Sep 17 00:00:00 2001
From: 阳洁 <2077506045@qq.com>
Date: 星期二, 18 七月 2023 10:44:54 +0800
Subject: [PATCH] 测评系统自动测试

---
 base/base_page.py               |   22 ++
 elements/caq_answer_elements.py |   36 ++++
 testcase/test_caq.py            |  185 +++++++++++++++++++++++
 po/caq_answer_page.py           |  141 +++++++++++++++++
 data/test_data.json             |   18 ++
 report/report.html              |   69 +++++++-
 6 files changed, 457 insertions(+), 14 deletions(-)

diff --git a/base/base_page.py b/base/base_page.py
index b2e29d3..6bcb658 100644
--- a/base/base_page.py
+++ b/base/base_page.py
@@ -37,13 +37,21 @@
         return self.driver.find_element(*locator)
 
     # 浣跨敤js璇彞鐐瑰嚮
-    def script_click(self, *locator):
+    def click_js(self, *locator):
         item = self.get_element(*locator)
         self.driver.execute_script("arguments[0].click();", item)
 
-    def script_click_wait(self, *locator):
+    def click_js_wait(self, *locator):
         item = self.get_element_wait(*locator)
         self.driver.execute_script("arguments[0].click();", item)
+
+    def click_element_js(self, element):
+        """
+        浣跨敤js鐐瑰嚮鍏冪礌
+        :param element: 瑕佺偣鍑荤殑鍏冪礌
+        :return:
+        """
+        self.driver.execute_script("arguments[0].click();", element)
 
     # 鐐瑰嚮
     def click(self, locator):
@@ -153,3 +161,13 @@
         self.switch_window(-1)
         # 鍦ㄦ柊鏍囩椤典腑鍔犺浇鎸囧畾url
         self.driver.get(url)
+
+    def elements_is_visibility(self, locator):
+        """
+        鍒ゆ柇鏄惁鑷冲皯鏈変竴涓厓绱犲湪椤甸潰涓彲瑙�
+        :param locator:
+        :return:
+        """
+        wait = WebDriverWait(self.driver, 10, 0.5)
+        return wait.until(EC.visibility_of_any_elements_located(locator))
+
diff --git a/data/test_data.json b/data/test_data.json
index 6adf9db..4e40606 100644
--- a/data/test_data.json
+++ b/data/test_data.json
@@ -45,5 +45,23 @@
       "position":"鑱屽憳",
       "dept": "浜轰簨閮�"
     }
+  },
+  "CAQ": {
+    "menu": "娴嬭瘯鍖呯鐞�/娴嬭瘯鍖呭垪琛�",
+    "add": {
+      "company": "TAI娴嬭瘯",
+      "type": "鏅哄姏娴嬮獙鍖�",
+      "product": "CAQ",
+      "hrEmail": "2077506045@qq.com",
+      "invalid": "2024-01-01 00:00:00",
+      "memberLang": "涓枃",
+      "hrReportLang": "涓枃",
+      "reportTemplate": "CAQ-CAQ-Chinese",
+      "memberReportLang": "涓枃"
+    },
+    "info": {
+      "position":"鑱屽憳",
+      "dept": "浜轰簨閮�"
+    }
   }
 }
\ No newline at end of file
diff --git a/elements/caq_answer_elements.py b/elements/caq_answer_elements.py
new file mode 100644
index 0000000..e5da581
--- /dev/null
+++ b/elements/caq_answer_elements.py
@@ -0,0 +1,36 @@
+from selenium.webdriver.common.by import By
+
+
+class CAQAnswerElements:
+    # 寮�濮嬫祴璇曟寜閽�
+    start_btn = (By.XPATH, "//button")
+    # 棰樼洰閫夐」-1
+    options_1 = (By.XPATH, "//div[@class='el-card__body']/div[3]//span[@class='q-item-span-content']/../..")
+    # 棰樼洰閫夐」-2
+    options_2 = (By.XPATH, "//div[@class='el-card__body']/div[4]//span[@class='q-item-span-content']/../..")
+    # 棰樼洰閫夐」-3
+    options_3 = (By.XPATH, "//div[@class='el-card__body']/div[5]//span[@class='q-item-span-content']/../..")
+    # 棰樼洰閫夐」-4
+    options_4 = (By.XPATH, "//div[@class='el-card__body']/div[6]//span[@class='q-item-span-content']/../..")
+    # 棰樼洰閫夐」-5
+    options_5 = (By.XPATH, "//div[@class='el-card__body']/div[7]//span[@class='q-item-span-content']/../..")
+    # 棰樼洰閫夐」-6
+    options_6 = (By.XPATH, "//div[@class='el-card__body']/div[2]//span[@class='q-item-span-content']/../..")
+
+    # 绂佺敤鐨勯�夐」
+    disabled = (By.XPATH, "//label[@aria-disabled='true']")
+    # 缁х画娴嬭瘯鎸夐挳
+    continue_testing_btn = (By.XPATH, "//button/span[text()='缁х画娴嬭瘯']/..")
+    # 涓嬩竴棰樻寜閽�
+    next_btn = (By.XPATH, "//button/span[text()='涓嬩竴棰�']/..")
+    # 鎻愪氦鎸夐挳
+    submit_btn = (By.XPATH, "//button/span[contains(text(),'鎻愪氦')]/..")
+    # 涓婁紶鎴愬姛鏍囬
+    upload_success_title = (By.XPATH, "//main/h2[contains(text(), '鏁版嵁宸茬粡鎴愬姛鍦颁笂浼犺嚦鏈嶅姟鍣�')]")
+
+    # 鍔犺浇妗嗘枃瀛�
+    loading_text = (By.XPATH, "//div[@class='el-loading-spinner']/p")
+
+    # 鏍囬鏂囧瓧
+    title = (By.XPATH, "//div[@class='align-center']/span[2]")
+
diff --git a/po/caq_answer_page.py b/po/caq_answer_page.py
new file mode 100644
index 0000000..86b7fd3
--- /dev/null
+++ b/po/caq_answer_page.py
@@ -0,0 +1,141 @@
+import random
+
+from base.base_page import BasePage
+from elements.caq_answer_elements import CAQAnswerElements as Answer
+from selenium.common.exceptions import *
+
+import time
+
+
+class CAQAnswerPage(BasePage):
+    """
+    绛旈椤甸潰
+    """
+    loading_count = 0
+
+    def answer_MAQ(self):
+        # 鏆傚仠3绉�
+        time.sleep(3)
+        i = 0
+        while i < 27:
+            if i == 0:
+                self.click_wait(Answer.continue_testing_btn)
+            elif i < 4:
+                # 鑾峰彇鍒版墍鏈夐�夐」
+                options_1 = self.elements_is_visibility(Answer.options_1)
+                number = random.randint(0, 4)
+                self.click_element_js(options_1[number])
+
+                options_2 = self.elements_is_visibility(Answer.options_2)
+                self.click_element_js(options_2[number])
+
+                options_3 = self.elements_is_visibility(Answer.options_3)
+                self.click_element_js(options_3[number])
+
+                options_4 = self.elements_is_visibility(Answer.options_4)
+                self.click_element_js(options_4[number])
+
+                options_5 = self.elements_is_visibility(Answer.options_5)
+                self.click_element_js(options_5[number])
+
+                self.click_js(Answer.next_btn)
+            if i == 4:
+                self.click_wait(Answer.continue_testing_btn)
+
+            # # 鏍囬涓嶅瓨鍦ㄧ洿鎺ヨ繑鍥濬alse
+            # if not self.title_is_display():
+            #     return False
+
+            if 4 < i < 26:
+                options_6 = self.elements_is_visibility(Answer.options_6)
+                number = random.randint(0, 4)
+                self.click_element_js(options_6[number])
+                if i == 23:
+                    self.click_js(Answer.submit_btn)
+                    # 鏁版嵁鏄惁涓婁紶瀹屾垚
+                    time.sleep(15)
+                    if self.upload_is_success():
+                        return True
+                else:
+
+                    self.click_js(Answer.next_btn)
+            i += 1
+
+    def upload_is_success(self):
+        """
+        鍒ゆ柇鏁版嵁鏄惁涓婁紶瀹屾垚
+        :return:
+        """
+        i = 0
+        while i < 60:
+            try:
+                self.get_element_wait(Answer.upload_success_title)
+                return True
+            except TimeoutException:
+                i += 1
+                time.sleep(1)
+        return False
+
+    def submit_btn_is_display(self):
+        """
+        鍒ゆ柇鎻愪氦鎸夐挳鏄惁瀛樺湪
+        :return:
+        """
+        try:
+            button = self.get_element(Answer.submit_btn)
+            if button.is_enabled():
+                return True
+            else:
+                return False
+        except NoSuchElementException:
+            return False
+
+    def continue_btn_is_display(self):
+        """
+        鍒ゆ柇缁х画娴嬭瘯鎸夐挳鏄惁鍑虹幇
+        :return: bool
+        """
+        try:
+            # 鐐瑰嚮缁х画娴嬭瘯鎸夐挳
+            button = self.get_element(Answer.continue_testing_btn)
+            if button.is_enabled():
+                return True
+            else:
+                return False
+        except NoSuchElementException:
+            return False
+
+    def title_is_display(self):
+        """
+        鍒ゆ柇鏍囬鏄惁鍑虹幇
+        :return: bool
+        """
+        try:
+            # 鑾峰彇鏍囬
+            self.get_element_wait(Answer.title)
+            return True
+        except TimeoutException:
+            return False
+
+    def loadin_text(self):
+        """
+        鍒ゆ柇鍔犺浇妗嗗姞杞斤紝濡傛灉鍔犺浇瓒呰繃10绉掔洿鎺ラ��鍑哄綋鍓嶆祴璇�
+        :return:
+        """
+        i = 0
+        while i < 10:
+            try:
+                self.get_element(Answer.loading_text)
+                i += 1
+                time.sleep(1)
+            except:
+                return False
+        else:
+            return True
+
+    def start_btn(self):
+        """
+        寮�濮嬫祴璇曟寜閽�
+        :return:
+        """
+        self.click_wait(Answer.start_btn)
diff --git a/report/report.html b/report/report.html
index 4b70cf8..42d4c6f 100644
--- a/report/report.html
+++ b/report/report.html
@@ -253,10 +253,10 @@
 }
 </script>
     <h1>report.html</h1>
-    <p>Report generated on 17-Jul-2023 at 16:56:23 by <a href="https://pypi.python.org/pypi/pytest-html">pytest-html</a> v3.2.0</p>
+    <p>Report generated on 18-Jul-2023 at 10:42:26 by <a href="https://pypi.python.org/pypi/pytest-html">pytest-html</a> v3.2.0</p>
     <h2>Summary</h2>
-    <p>10 tests ran in 385.15 seconds. </p>
-    <p class="filter" hidden="true">(Un)check the boxes to filter the results.</p><input checked="true" class="filter" data-test-result="passed" hidden="true" name="filter_checkbox" onChange="filterTable(this)" type="checkbox"/><span class="passed">10 passed</span>, <input checked="true" class="filter" data-test-result="skipped" disabled="true" hidden="true" name="filter_checkbox" onChange="filterTable(this)" type="checkbox"/><span class="skipped">0 skipped</span>, <input checked="true" class="filter" data-test-result="failed" disabled="true" hidden="true" name="filter_checkbox" onChange="filterTable(this)" type="checkbox"/><span class="failed">0 failed</span>, <input checked="true" class="filter" data-test-result="error" disabled="true" hidden="true" name="filter_checkbox" onChange="filterTable(this)" type="checkbox"/><span class="error">0 errors</span>, <input checked="true" class="filter" data-test-result="xfailed" disabled="true" hidden="true" name="filter_checkbox" onChange="filterTable(this)" type="checkbox"/><span class="xfailed">0 expected failures</span>, <input checked="true" class="filter" data-test-result="xpassed" disabled="true" hidden="true" name="filter_checkbox" onChange="filterTable(this)" type="checkbox"/><span class="xpassed">0 unexpected passes</span>
+    <p>15 tests ran in 440.22 seconds. </p>
+    <p class="filter" hidden="true">(Un)check the boxes to filter the results.</p><input checked="true" class="filter" data-test-result="passed" hidden="true" name="filter_checkbox" onChange="filterTable(this)" type="checkbox"/><span class="passed">15 passed</span>, <input checked="true" class="filter" data-test-result="skipped" disabled="true" hidden="true" name="filter_checkbox" onChange="filterTable(this)" type="checkbox"/><span class="skipped">0 skipped</span>, <input checked="true" class="filter" data-test-result="failed" disabled="true" hidden="true" name="filter_checkbox" onChange="filterTable(this)" type="checkbox"/><span class="failed">0 failed</span>, <input checked="true" class="filter" data-test-result="error" disabled="true" hidden="true" name="filter_checkbox" onChange="filterTable(this)" type="checkbox"/><span class="error">0 errors</span>, <input checked="true" class="filter" data-test-result="xfailed" disabled="true" hidden="true" name="filter_checkbox" onChange="filterTable(this)" type="checkbox"/><span class="xfailed">0 expected failures</span>, <input checked="true" class="filter" data-test-result="xpassed" disabled="true" hidden="true" name="filter_checkbox" onChange="filterTable(this)" type="checkbox"/><span class="xpassed">0 unexpected passes</span>
     <h2>Results</h2>
     <table id="results-table">
       <thead id="results-table-head">
@@ -270,8 +270,53 @@
       <tbody class="passed results-table-row">
         <tr>
           <td class="col-result">Passed</td>
+          <td class="col-name">testcase/test_caq.py::TestCAQ::test_login[login]</td>
+          <td class="col-duration">5.40</td>
+          <td class="col-links"></td></tr>
+        <tr>
+          <td class="extra" colspan="4">
+            <div class="empty log">No log output captured.</div></td></tr></tbody>
+      <tbody class="passed results-table-row">
+        <tr>
+          <td class="col-result">Passed</td>
+          <td class="col-name">testcase/test_caq.py::TestCAQ::test_create_package[CAQ]</td>
+          <td class="col-duration">14.57</td>
+          <td class="col-links"></td></tr>
+        <tr>
+          <td class="extra" colspan="4">
+            <div class="empty log">No log output captured.</div></td></tr></tbody>
+      <tbody class="passed results-table-row">
+        <tr>
+          <td class="col-result">Passed</td>
+          <td class="col-name">testcase/test_caq.py::TestCAQ::test_open_url[CAQ]</td>
+          <td class="col-duration">12.74</td>
+          <td class="col-links"></td></tr>
+        <tr>
+          <td class="extra" colspan="4">
+            <div class="empty log">No log output captured.</div></td></tr></tbody>
+      <tbody class="passed results-table-row">
+        <tr>
+          <td class="col-result">Passed</td>
+          <td class="col-name">testcase/test_caq.py::TestCAQ::test_answer</td>
+          <td class="col-duration">20.70</td>
+          <td class="col-links"></td></tr>
+        <tr>
+          <td class="extra" colspan="4">
+            <div class="empty log">No log output captured.</div></td></tr></tbody>
+      <tbody class="passed results-table-row">
+        <tr>
+          <td class="col-result">Passed</td>
+          <td class="col-name">testcase/test_caq.py::TestCAQ::test_delete_package</td>
+          <td class="col-duration">7.31</td>
+          <td class="col-links"></td></tr>
+        <tr>
+          <td class="extra" colspan="4">
+            <div class="empty log">No log output captured.</div></td></tr></tbody>
+      <tbody class="passed results-table-row">
+        <tr>
+          <td class="col-result">Passed</td>
           <td class="col-name">testcase/test_jaq.py::TestJAQ::test_login[login]</td>
-          <td class="col-duration">6.38</td>
+          <td class="col-duration">5.34</td>
           <td class="col-links"></td></tr>
         <tr>
           <td class="extra" colspan="4">
@@ -280,7 +325,7 @@
         <tr>
           <td class="col-result">Passed</td>
           <td class="col-name">testcase/test_jaq.py::TestJAQ::test_create_package[JAQ]</td>
-          <td class="col-duration">14.17</td>
+          <td class="col-duration">14.65</td>
           <td class="col-links"></td></tr>
         <tr>
           <td class="extra" colspan="4">
@@ -289,7 +334,7 @@
         <tr>
           <td class="col-result">Passed</td>
           <td class="col-name">testcase/test_jaq.py::TestJAQ::test_open_url[JAQ]</td>
-          <td class="col-duration">12.09</td>
+          <td class="col-duration">13.02</td>
           <td class="col-links"></td></tr>
         <tr>
           <td class="extra" colspan="4">
@@ -298,7 +343,7 @@
         <tr>
           <td class="col-result">Passed</td>
           <td class="col-name">testcase/test_jaq.py::TestJAQ::test_answer</td>
-          <td class="col-duration">78.51</td>
+          <td class="col-duration">78.60</td>
           <td class="col-links"></td></tr>
         <tr>
           <td class="extra" colspan="4">
@@ -307,7 +352,7 @@
         <tr>
           <td class="col-result">Passed</td>
           <td class="col-name">testcase/test_jaq.py::TestJAQ::test_delete_package</td>
-          <td class="col-duration">7.33</td>
+          <td class="col-duration">7.35</td>
           <td class="col-links"></td></tr>
         <tr>
           <td class="extra" colspan="4">
@@ -316,7 +361,7 @@
         <tr>
           <td class="col-result">Passed</td>
           <td class="col-name">testcase/test_maq.py::TestMAQ::test_login[login]</td>
-          <td class="col-duration">4.86</td>
+          <td class="col-duration">5.41</td>
           <td class="col-links"></td></tr>
         <tr>
           <td class="extra" colspan="4">
@@ -325,7 +370,7 @@
         <tr>
           <td class="col-result">Passed</td>
           <td class="col-name">testcase/test_maq.py::TestMAQ::test_create_package[MAQ]</td>
-          <td class="col-duration">14.06</td>
+          <td class="col-duration">14.58</td>
           <td class="col-links"></td></tr>
         <tr>
           <td class="extra" colspan="4">
@@ -334,7 +379,7 @@
         <tr>
           <td class="col-result">Passed</td>
           <td class="col-name">testcase/test_maq.py::TestMAQ::test_open_url[MAQ]</td>
-          <td class="col-duration">12.22</td>
+          <td class="col-duration">12.80</td>
           <td class="col-links"></td></tr>
         <tr>
           <td class="extra" colspan="4">
@@ -343,7 +388,7 @@
         <tr>
           <td class="col-result">Passed</td>
           <td class="col-name">testcase/test_maq.py::TestMAQ::test_answer</td>
-          <td class="col-duration">227.95</td>
+          <td class="col-duration">220.16</td>
           <td class="col-links"></td></tr>
         <tr>
           <td class="extra" colspan="4">
diff --git a/testcase/test_caq.py b/testcase/test_caq.py
new file mode 100644
index 0000000..82b40ea
--- /dev/null
+++ b/testcase/test_caq.py
@@ -0,0 +1,185 @@
+from datetime import datetime
+import time
+from selenium.webdriver.common.by import By
+
+import pytest
+from selenium import webdriver
+from po.login_page import LoginPage
+from po.home_page import HomePage
+from po.test_package_list_page import TestPackageListPage
+from po.share_add_page import ShareAddPage
+from po.caq_answer_page import CAQAnswerPage
+from comm.my_random import *
+
+
+class TestCAQ:
+    driver = None
+    test_package_name = "CAQ鑷姩娴嬭瘯鍖�-20230718101350"
+
+    @pytest.mark.parametrize('data_read', ["login"], indirect=True)
+    def test_login(self, data_read: dict):
+        """
+        鎵撳紑椤甸潰骞惰繘琛岀櫥褰曟祴璇�
+        :param data_read: 鎵ц鏁版嵁璇诲彇鐨勫嚱鏁板苟鑾峰彇鍒拌繑鍥炲��
+        :return:
+        """
+        TestCAQ.driver = webdriver.Chrome()
+        driver = TestCAQ.driver
+        login_page = LoginPage(driver)
+        try:
+            # 鎵撳紑閾炬帴
+            driver.get(data_read["url"])
+        except:
+            # 閾炬帴鎵撳紑鍑虹幇寮傚父璇存槑閾炬帴鏃犳硶璁块棶,鎹曡幏寮傚父浣嗕笉鍋氬鐞�
+            pass
+
+        # 娴忚鍣ㄧ獥鍙f渶澶у寲
+        driver.maximize_window()
+        # 鑾峰彇鍒板埛鏂版寜閽苟姣�10绉掔偣鍑讳竴娆�,鐭ラ亾鍒锋柊鎸夐挳娑堝け
+        while True:
+            try:
+                # 鍒ゆ柇鎵撳紑鐨勯〉闈㈡槸鍚﹀瓨鍦ㄥ埛鏂版寜閽�
+                reload_btn = login_page.get_element((By.XPATH, "//div[@id='buttons']/div/button[@id='reload-button']"))
+                # 鐐瑰嚮鍒锋柊鎸夐挳
+                reload_btn.click()
+                time.sleep(10)
+            except:
+                # 鍑虹幇寮傚父琛ㄧず涓嶅瓨鍦ㄥ埛鏂版寜閽�
+                # 鎺ョ潃鍒ゆ柇鏄惁瀛樺湪nginx error!
+                try:
+                    nginx_error = login_page.get_element((By.XPATH, "//strong[text() = 'nginx error!']"))
+                    # 瀛樺湪鍒欑潯鐪�10绉�
+                    time.sleep(10)
+                except:
+                    break
+
+        login_page.login(data_read["username"], data_read["password"], data_read["code"])
+        time.sleep(2)
+        assert login_page.is_login_success()
+
+    @pytest.mark.parametrize('data_read', ["CAQ"], indirect=True)
+    def test_create_package(self, data_read: dict):
+        """
+        鍒涘缓娴嬭瘯鍖�
+        :param data_read: 璇诲彇鏁版嵁
+        :return:
+        """
+        # 鑾峰彇driver
+        driver = TestCAQ.driver
+        # 鍒涘缓home椤甸潰鐨勫璞�
+        home_page = HomePage(driver)
+        # 鐐瑰嚮宸︿晶鑿滃崟杩涘叆椤甸潰
+        home_page.menu_select(data_read["menu"])
+        # 鍒涘缓娴嬭瘯鍖呭垪琛ㄩ〉闈㈢殑瀵硅薄
+        test_package_list = TestPackageListPage(driver)
+        # 鐐瑰嚮鍒涘缓鎸夐挳
+        test_package_list.create_btn()
+        # 鑾峰彇褰撳墠鏃堕棿
+        current_time = datetime.now()
+        # 杞崲涓哄瓧绗︿覆
+        time_str = current_time.strftime("%Y%m%d%H%M%S")
+        # 鍒涘缓娴嬭瘯鍖呭~鍐欑殑鍙傛暟
+        # 娴嬭瘯鍖呭悕绉�
+        test_package_name = "CAQ鑷姩娴嬭瘯鍖�-" + time_str
+        # 璁剧疆娴嬭瘯鍖呭悕绉颁负绫诲彉閲�
+        TestCAQ.test_package_name = test_package_name
+        # 鑾峰彇鍒涘缓娴嬭瘯鍖呯殑鏁版嵁
+        create_data = data_read["add"]
+        # 濉啓娴嬭瘯鍖呭悕绉�
+        test_package_list.testPackageName_input(test_package_name)
+        # 濉啓鎶ュ憡浼佷笟鍚嶇О
+        test_package_list.reportCompanyName_input(create_data["company"])
+        # 閫夋嫨娴嬭瘯鍖呯被鍨�
+        test_package_list.testPackageType_select(create_data["type"])
+        # 閫夋嫨浜у搧鍖�
+        test_package_list.prodTree_select(create_data["product"])
+        # 杈撳叆hr閭
+        test_package_list.hrReportEmail_input(create_data["hrEmail"])
+        # 杈撳叆鏈夋晥鏈�
+        test_package_list.invalidTime_input(create_data["invalid"])
+        # 閫夋嫨閭�璇烽偖浠惰瑷�绫诲瀷
+        test_package_list.testTemplateLangType_select(create_data["memberLang"])
+        # 閫夋嫨HR閭欢璇█绫诲瀷
+        test_package_list.hrTemplateLangType_select(create_data["hrReportLang"])
+        # 閫夋嫨鎶ュ憡妯℃澘
+        test_package_list.reportTemplate_select(create_data["reportTemplate"])
+        # 鐐瑰嚮娴嬭瘯鑰呮帴鏀舵姤鍛�
+        test_package_list.autoSendReport_checkbox()
+        # 閫夋嫨娴嬭瘯鑰呮姤鍛婇偖绠辫瑷�绫诲瀷
+        test_package_list.memberReportLangType_select(create_data["memberReportLang"])
+        # 鐐瑰嚮纭鎸夐挳
+        test_package_list.add_confirm()
+        time.sleep(2)
+        # 鍒ゆ柇鏄惁鎴愬姛鍒涘缓
+        assert test_package_list.is_create_success(test_package_name)
+        time.sleep(5)
+
+    @pytest.mark.parametrize('data_read', ["CAQ"], indirect=True)
+    def test_open_url(self, data_read: dict):
+        """
+        鎵撳紑鍒嗕韩閾炬帴
+        :return:
+        """
+        # 鑾峰彇driver
+        driver = TestCAQ.driver
+        #     # 鍒涘缓home椤甸潰鐨勫璞�
+        #     home_page = HomePage(driver)
+        #     # 鐐瑰嚮宸︿晶鑿滃崟杩涘叆椤甸潰
+        #     home_page.menu_select(data_read["menu"])
+        # 鍒涘缓娴嬭瘯鍖呭垪琛ㄩ〉闈㈢殑瀵硅薄
+        test_package_list = TestPackageListPage(driver)
+        # 鍕鹃�夋柊鍒涘缓鐨勬祴璇曞寘
+        test_package_list.click_package_checkbox(TestCAQ.test_package_name)
+        # 鐐瑰嚮鐢熸垚鍒嗕韩閾炬帴鎸夐挳
+        test_package_list.click_share_1_btn()
+        # 鑾峰彇鍒皍rl
+        url = test_package_list.get_share_url()
+        # 鎵撳紑鏂版爣绛鹃〉鍔犺浇url
+        test_package_list.open_new_table_to_url(url)
+        # 鍒涘缓鍒嗕韩椤甸潰瀵硅薄
+        share_add = ShareAddPage(driver)
+        # 濉啓淇℃伅鎻愪氦骞惰幏鍙栨祴璇曢摼鎺�
+        name = random_string(8)
+        email = name + "@gmail.com"
+        test_url = share_add.page_default_operation(name, email)
+        # 褰撳墠椤甸潰鎵撳紑閾炬帴
+        driver.get(test_url)
+        # 鐐瑰嚮鎻愪氦鎸夐挳
+        share_add.submit_btn()
+        # 鑾峰彇鏁版嵁
+        info = data_read["info"]
+        # 濉啓鍩烘湰淇℃伅骞舵彁浜�
+        share_add.fill_info(email, info["position"], info["dept"])
+        time.sleep(5)
+
+    def test_answer(self):
+        # 鑾峰彇driver
+        driver = TestCAQ.driver
+        # 鍒涘缓answer瀵硅薄
+        answer_page = CAQAnswerPage(driver)
+        # 鐐瑰嚮寮�濮嬫祴璇�
+        answer_page.start_btn()
+        # 寮�濮嬬瓟棰�
+        flag = answer_page.answer_MAQ()
+        # 绛斿畬棰樺叧闂綋鍓嶆爣绛鹃〉
+        driver.close()
+        # 鍒囨崲鍒扮涓�涓爣绛鹃〉
+        answer_page.switch_window(0)
+        if flag is not None or not flag:
+            assert flag
+            return
+
+    def test_delete_package(self):
+        # 鑾峰彇driver
+        driver = TestCAQ.driver
+        # 鍒涘缓娴嬭瘯鍖呭垪琛ㄩ〉闈㈢殑瀵硅薄
+        test_package_list = TestPackageListPage(driver)
+        # 鍒犻櫎娴嬭瘯鍖�
+        test_package_list.delete_package()
+        time.sleep(5)
+        # 鍏抽棴
+        driver.quit()
+
+
+if __name__ == '__main__':
+    pytest.main(["-s", __file__])

--
Gitblit v1.9.1