BUG352-NEIL2 #68

Closed
mrlan wants to merge 2 commits from BUG352-NEIL2 into Hui-Organize
12 changed files with 100 additions and 38 deletions

8
test/SeleniumNeil/.idea/.gitignore vendored Normal file
View File

@ -0,0 +1,8 @@
# Default ignored files
/shelf/
/workspace.xml
# Editor-based HTTP Client requests
/httpRequests/
# Datasource local storage ignored files
/dataSources/
/dataSources.local.xml

View File

@ -0,0 +1,15 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="PYTHON_MODULE" version="4">
<component name="NewModuleRootManager">
<content url="file://$MODULE_DIR$" />
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
<component name="PyDocumentationSettings">
<option name="format" value="PLAIN" />
<option name="myDocStringFormat" value="Plain" />
</component>
<component name="TestRunnerService">
<option name="PROJECT_TEST_RUNNER" value="py.test" />
</component>
</module>

View File

@ -0,0 +1,6 @@
<component name="InspectionProjectProfileManager">
<settings>
<option name="USE_PROJECT_PROFILE" value="false" />
<version value="1.0" />
</settings>
</component>

View File

@ -0,0 +1,4 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectRootManager" version="2" project-jdk-name="Python 3.8" project-jdk-type="Python SDK" />
</project>

View File

@ -0,0 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/.idea/SeleniumNeil.iml" filepath="$PROJECT_DIR$/.idea/SeleniumNeil.iml" />
</modules>
</component>
</project>

View File

@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="$PROJECT_DIR$/../.." vcs="Git" />
</component>
</project>

1
test/SeleniumNeil/LRR Submodule

@ -0,0 +1 @@
Subproject commit 1a01b4facd4c9d1cce59ef84da114f55a57f616d

Binary file not shown.

View File

@ -0,0 +1,33 @@
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.common.exceptions import NoSuchElementException, UnexpectedAlertPresentException
def login(driver, url, username, password):
try:
driver.get(url)
# Fill in the login form
user_input = WebDriverWait(driver, 10).until(
EC.element_to_be_clickable((By.ID, "user_name"))
)
user_input.send_keys(username)
password_input = WebDriverWait(driver, 10).until(
EC.element_to_be_clickable((By.ID, "user_password"))
)
password_input.send_keys(password)
# Click the login button
login_button = WebDriverWait(driver, 10).until(
EC.element_to_be_clickable((By.ID, "login_btn"))
)
login_button.click()
# Wait for the admin_tab to become clickable
admin_tab = WebDriverWait(driver, 10).until(
EC.element_to_be_clickable((By.ID, "admin_tab"))
)
except (NoSuchElementException, UnexpectedAlertPresentException) as e:
return f"Error: {str(e)}"

View File

@ -10,7 +10,9 @@ from selenium.webdriver.common.by import By
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
def test_function_1(restore_database):
assert restore_database is None
@pytest.mark.skip(reason="function to be used in the test_scripts")
def createTA(driver, TA_name, emails, password):
@ -25,34 +27,11 @@ def createTA(driver, TA_name, emails, password):
click_create = driver.find_element('name', 'create_btn')
click_create.click()
def login_lecturer(drivers):
# Open the website
drivers.get("http://localhost/LRR/")
drivers.maximize_window()
username_input = drivers.find_element('name', "user")
password_input = drivers.find_element('name', "password")
login_button = drivers.find_element('id', "login_btn")
# login as a Lecturer
username_input.send_keys("admin@qq.com")
password_input.send_keys("123")
# Click the login button
time.sleep(10)
login_button.click()
admin_tab = drivers.find_element('id', 'admin_tab')
admin_tab.click()
cte_instructor = drivers.find_element('id', 'tab_ins_accounts')
cte_instructor.click()
time.sleep(15)
def test_createTA():
driver_open = webdriver.Chrome()
def test_createTA(url, driver, restore_database):
driver_open = driver
driver_open.maximize_window()
login_lecturer(driver_open)
login(driver, url, "admin@qq.com", "123")
try:
fullname = "lanhuitest1"
email = "lanhuitest1@qq.com"
@ -85,13 +64,13 @@ def test_createTA():
time.sleep(10)
login_button.click()
assert result == "Passed", f"Test Case 1 create TA passed"
time.sleep(5)
elif txt_alert.find("Email address ") == 0:
time.sleep(10)
driver_open.quit()
assert result == "Passed", f"Test Case 1 create TA failed"
else:
driver_open.quit()
@ -99,11 +78,9 @@ def test_createTA():
finally:
driver_open.quit()
def test_generate_password():
driver_open = webdriver.Chrome()
login_lecturer(driver_open)
def test_generate_password(url, driver, restore_database):
driver_open = driver
login(driver, url, "admin@qq.com", "123")
try:
fullname = "lanhuitest2"
email = "lanhuitest2@qq.com"
@ -145,13 +122,13 @@ def test_generate_password():
time.sleep(15)
login_button.click()
assert result == "Passed", f"Test Case 2 generate passsword passed"
time.sleep(5)
elif txt_alert.find("Email address ") == 0:
time.sleep(15)
driver_open.quit()
assert result == "Passed", f"Test Case 2 generate passsword failed"
else:
driver_open.quit()
@ -160,9 +137,9 @@ def test_generate_password():
finally:
driver_open.quit()
def test_existingTA():
driver_open = webdriver.Chrome()
login_lecturer(driver_open)
def test_existingTA(url, driver, restore_database):
driver_open = driver
login(driver, url, "admin@qq.com", "123")
try:
# Use email nreyes@example.com as account name and new1452345678 as password.
fullname = "lanhuitest1"
@ -180,11 +157,14 @@ def test_existingTA():
time.sleep(15)
if txt_alert.find("TA user created successfully") == 0:
assert result == "Passed", f"Test Case 2 existing account passed"
time.sleep(5)
elif txt_alert.find("Email address ") == 0:
time.sleep(15)
assert result == "Passed", f"Test Case 2 existing account failed"
driver_open.quit()
else:
@ -194,3 +174,4 @@ def test_existingTA():
finally:
driver_open.quit()