fix 02 tests (except Bach problem)

This commit is contained in:
Jean-Marie Place 2021-08-08 07:39:21 +02:00
parent d3d6b01931
commit 2a57748959
3 changed files with 82 additions and 70 deletions

View File

@ -22,6 +22,12 @@ from selenium.webdriver.common.keys import Keys
from selenium.webdriver.support.ui import Select from selenium.webdriver.support.ui import Select
from selenium.webdriver.support.select import Select from selenium.webdriver.support.select import Select
URL_ROOT = SCHEMA + "://" + BASE_URL
URL_AUTH = "/".join((URL_ROOT, "auth", "login"))
URL_SCODOC8 = "/".join((URL_ROOT, "index"))
URL_HOME = "/".join((URL_ROOT, "ScoDoc", "index"))
URL_DEPT = "/".join((URL_ROOT, "ScoDoc", NOM_DPT, "Scolarite", "index_html"))
URL_ADMIN = "/".join((URL_ROOT, "ScoDoc", "admin"))
class PythonOrgSearch(unittest.TestCase): class PythonOrgSearch(unittest.TestCase):
# Permet de se connecter et se remettre sur la page d'accueil avant chaque test # Permet de se connecter et se remettre sur la page d'accueil avant chaque test
@ -31,12 +37,12 @@ class PythonOrgSearch(unittest.TestCase):
self.driver = webdriver.Firefox() self.driver = webdriver.Firefox()
else: else:
self.driver = webdriver.Chrome() self.driver = webdriver.Chrome()
auth_page = SCHEMA + "://" + BASE_SSH_URL + "auth/login?next=%2F" + next_page auth_page = URL_AUTH + "?next=%2F" + next_page
self.driver.get(auth_page) self.driver.get(auth_page)
self.driver.find_element_by_id("user_name").send_keys(SCODOC_ADMIN_ID) self.driver.find_element_by_id("user_name").send_keys(SCODOC_ADMIN_ID)
self.driver.find_element_by_id("password").send_keys(SCODOC_ADMIN_PASS) self.driver.find_element_by_id("password").send_keys(SCODOC_ADMIN_PASS)
self.driver.find_element_by_id("submit").click() self.driver.find_element_by_id("submit").click()
self.driver.get(SCHEMA + "://" + BASE_URL) self.driver.get(URL_SCODOC8)
# Test : Verification de la connexion admin effective # Test : Verification de la connexion admin effective
# @expected : "Bonjour admin" est présent sur la page d'accueil # @expected : "Bonjour admin" est présent sur la page d'accueil
@ -55,7 +61,7 @@ class PythonOrgSearch(unittest.TestCase):
driver.find_element_by_id("create-dept").submit() driver.find_element_by_id("create-dept").submit()
time.sleep(1) time.sleep(1)
driver.find_element_by_id("tf_submit").click() driver.find_element_by_id("tf_submit").click()
driver.get(SCHEMA + "://" + BASE_URL) driver.get(URL_HOME)
self.assertTrue(NOM_DPT in driver.page_source) self.assertTrue(NOM_DPT in driver.page_source)
# Test : Suppresion d'un département, puis lancement d'un script coté serveur pour supprimer sa base de données # Test : Suppresion d'un département, puis lancement d'un script coté serveur pour supprimer sa base de données

View File

@ -24,10 +24,15 @@ from selenium.webdriver.common.keys import Keys
from selenium.webdriver.support.ui import Select from selenium.webdriver.support.ui import Select
from selenium.webdriver.support.select import Select from selenium.webdriver.support.select import Select
URL = SCHEMA + "://" + BASE_URL + NOM_DPT + "/Scolarite" URL_ROOT = SCHEMA + "://" + BASE_URL
URL_AUTH = "/".join((URL_ROOT, "auth", "login"))
URL_SCODOC8 = "/".join((URL_ROOT, "index"))
URL_HOME = "/".join((URL_ROOT, "ScoDoc", "index"))
URL_DEPT = "/".join((URL_ROOT, "ScoDoc", NOM_DPT, "Scolarite", "index_html"))
URL_ADMIN = "/".join((URL_ROOT, "ScoDoc", "admin"))
ACRONYME_FORMATION = "formationtest" ACRONYME_FORMATION = "formationtest"
URL = URL_SCODOC8
class PythonOrgSearch(unittest.TestCase): class PythonOrgSearch(unittest.TestCase):
# Permet de se connecter et se remettre sur la page d'accueil avant chaque test # Permet de se connecter et se remettre sur la page d'accueil avant chaque test
@ -37,23 +42,25 @@ class PythonOrgSearch(unittest.TestCase):
self.driver = webdriver.Firefox() self.driver = webdriver.Firefox()
else: else:
self.driver = webdriver.Chrome() self.driver = webdriver.Chrome()
auth_page = SCHEMA + "://" + BASE_SSH_URL + "auth/login?next=%2F" + next_page self.wait = WebDriverWait(self.driver, 10)
auth_page = URL_AUTH + ("?next=" + next_page).replace("/", "%2F")
self.driver.get(auth_page) self.driver.get(auth_page)
self.driver.find_element_by_id("user_name").send_keys(SCODOC_ADMIN_ID) self.driver.find_element_by_id("user_name").send_keys(SCODOC_ADMIN_ID)
self.driver.find_element_by_id("password").send_keys(SCODOC_ADMIN_PASS) self.driver.find_element_by_id("password").send_keys(SCODOC_ADMIN_PASS)
self.driver.find_element_by_id("submit").click() self.driver.find_element_by_id("submit").click()
self.driver.get(SCHEMA + "://" + BASE_URL) self.driver.get(URL_HOME)
# Test Creer une formation # Test Creer une formation
# @expected : La formation se trouve dans le tableau de la liste des formations # @expected : La formation se trouve dans le tableau de la liste des formations
def test_011_create_formation(self): def test_011_create_formation(self):
driver = self.driver
global URL global URL
driver.get(URL) driver = self.driver
wait = self.wait
driver.get(URL_DEPT)
driver.find_element_by_id("link-programmes").click() driver.find_element_by_id("link-programmes").click()
URL = driver.current_url URL = driver.current_url
driver.find_element_by_id("link-create-formation").click() driver.find_element_by_id("link-create-formation").click()
self.wait.until(EC.url_changes(URL)) wait.until(EC.url_changes(URL))
driver.find_element_by_id("tf_acronyme").send_keys(ACRONYME_FORMATION) driver.find_element_by_id("tf_acronyme").send_keys(ACRONYME_FORMATION)
driver.find_element_by_id("tf_titre").send_keys("TEST") driver.find_element_by_id("tf_titre").send_keys("TEST")
driver.find_element_by_id("tf_titre_officiel").send_keys("formation de test") driver.find_element_by_id("tf_titre_officiel").send_keys("formation de test")
@ -69,24 +76,24 @@ class PythonOrgSearch(unittest.TestCase):
# @expected : Le nom de la formation est changé sur la page des formations # @expected : Le nom de la formation est changé sur la page des formations
def test_012_change_name_formation(self): def test_012_change_name_formation(self):
driver = self.driver driver = self.driver
global URL wait = self.wait
driver.get(URL) driver.get(URL)
idEditFormation = "edit-formation-" + ACRONYME_FORMATION.replace(" ","-") id_edit_formation = "edit-formation-" + ACRONYME_FORMATION.replace(" ","-")
driver.find_element_by_id(idEditFormation).click() driver.find_element_by_id(id_edit_formation).click()
self.wait.until(EC.url_changes(URL)) wait.until(EC.url_changes(URL))
driver.find_element_by_id("tf_acronyme").send_keys(ACRONYME_FORMATION) driver.find_element_by_id("tf_acronyme").send_keys(ACRONYME_FORMATION)
driver.find_element_by_id("tf_submit").click() driver.find_element_by_id("tf_submit").click()
driver.get(URL) driver.get(URL)
formations = driver.find_elements_by_class_name("acronyme") formations = driver.find_elements_by_class_name("acronyme")
textElementAcronyme = [] text_element_acronyme = []
for formation in formations: for formation in formations:
textElementAcronyme.append(formation.text) text_element_acronyme.append(formation.text)
self.assertTrue(ACRONYME_FORMATION + ACRONYME_FORMATION in textElementAcronyme) self.assertTrue(ACRONYME_FORMATION + ACRONYME_FORMATION in text_element_acronyme)
# Remise du nom à celui de départ # Remise du nom à celui de départ
driver.get(URL) driver.get(URL)
idEditFormation = "edit-formation-" + ACRONYME_FORMATION + ACRONYME_FORMATION id_edit_formation = "edit-formation-" + ACRONYME_FORMATION + ACRONYME_FORMATION
driver.find_element_by_id(idEditFormation).click() driver.find_element_by_id(id_edit_formation).click()
self.wait.until(EC.url_changes(URL)) wait.until(EC.url_changes(URL))
driver.find_element_by_id("tf_acronyme").clear() driver.find_element_by_id("tf_acronyme").clear()
driver.find_element_by_id("tf_acronyme").send_keys(ACRONYME_FORMATION) driver.find_element_by_id("tf_acronyme").send_keys(ACRONYME_FORMATION)
driver.find_element_by_id("tf_submit").click() driver.find_element_by_id("tf_submit").click()
@ -95,10 +102,10 @@ class PythonOrgSearch(unittest.TestCase):
# @expected : La formation n'as pas pu être créée et on arrive donc sur un message d'erreur à la création # @expected : La formation n'as pas pu être créée et on arrive donc sur un message d'erreur à la création
def test_013_same_name_formation(self): def test_013_same_name_formation(self):
driver = self.driver driver = self.driver
global URL wait = self.wait
driver.get(URL) driver.get(URL)
driver.find_element_by_id("link-create-formation").click() driver.find_element_by_id("link-create-formation").click()
self.wait.until(EC.url_changes(URL)) wait.until(EC.url_changes(URL))
driver.find_element_by_id("tf_acronyme").send_keys(ACRONYME_FORMATION) driver.find_element_by_id("tf_acronyme").send_keys(ACRONYME_FORMATION)
driver.find_element_by_id("tf_titre").send_keys("TEST") driver.find_element_by_id("tf_titre").send_keys("TEST")
driver.find_element_by_id("tf_titre_officiel").send_keys("formation de test") driver.find_element_by_id("tf_titre_officiel").send_keys("formation de test")
@ -114,19 +121,19 @@ class PythonOrgSearch(unittest.TestCase):
# @Expected : L'UE est créée et elle apparait désormais dans la liste d'UE de la formation # @Expected : L'UE est créée et elle apparait désormais dans la liste d'UE de la formation
def test_014_ajout_UE(self): def test_014_ajout_UE(self):
driver = self.driver driver = self.driver
global URL wait = self.wait
driver.get(URL) driver.get(URL)
idTitre = "titre-" + ACRONYME_FORMATION.replace(" ", "-") id_titre = "titre-" + ACRONYME_FORMATION.lower().replace(" ", "-")
driver.find_element_by_id(idTitre).click() driver.find_element_by_id(id_titre).click()
self.wait.until(EC.url_changes(URL)) wait.until(EC.url_changes(URL))
driver.find_element_by_xpath("//a[contains(@href,'ue_create?')]").click() driver.find_element_by_xpath("//a[contains(@href,'ue_create?')]").click()
driver.find_element_by_id("tf_titre").send_keys("UE TEST") driver.find_element_by_id("tf_titre").send_keys("UE TEST")
driver.find_element_by_id("tf_acronyme").send_keys("TEST") driver.find_element_by_id("tf_acronyme").send_keys("TEST")
driver.find_element_by_id("tf_submit").click() driver.find_element_by_id("tf_submit").click()
time.sleep(1) time.sleep(1)
driver.get(URL) driver.get(URL)
driver.find_element_by_id(idTitre).click() driver.find_element_by_id(id_titre).click()
self.wait.until(EC.url_changes(URL)) wait.until(EC.url_changes(URL))
self.assertTrue("TEST UE TEST" in driver.page_source) self.assertTrue("TEST UE TEST" in driver.page_source)
driver.get(URL) driver.get(URL)
@ -134,13 +141,13 @@ class PythonOrgSearch(unittest.TestCase):
# @Expected : La matière est créée et elle apparait désormais sur la page de détail de la formation # @Expected : La matière est créée et elle apparait désormais sur la page de détail de la formation
def test_015_ajout_matiere(self): def test_015_ajout_matiere(self):
driver = self.driver driver = self.driver
global URL wait = self.wait
nomMat = "unematieretest"
driver.get(URL) driver.get(URL)
nomMat = "unematieretest"
time.sleep(3) time.sleep(3)
idTitre = "titre-" + ACRONYME_FORMATION idTitre = "titre-" + ACRONYME_FORMATION.lower().replace(" ", "-")
driver.find_element_by_id(idTitre).click() driver.find_element_by_id(idTitre).click()
self.wait.until(EC.url_changes(URL)) wait.until(EC.url_changes(URL))
time.sleep(3) time.sleep(3)
driver.find_element_by_xpath("//a[contains(@href,'matiere_create?')]").click() driver.find_element_by_xpath("//a[contains(@href,'matiere_create?')]").click()
driver.find_element_by_id("tf_titre").send_keys(nomMat) driver.find_element_by_id("tf_titre").send_keys(nomMat)
@ -150,7 +157,7 @@ class PythonOrgSearch(unittest.TestCase):
driver.get(URL) driver.get(URL)
driver.find_element_by_id(idTitre).click() driver.find_element_by_id(idTitre).click()
time.sleep(3) time.sleep(3)
self.wait.until(EC.url_changes(URL)) wait.until(EC.url_changes(URL))
elements = driver.find_elements_by_xpath("//a[contains(@href,'matiere_edit?')]") elements = driver.find_elements_by_xpath("//a[contains(@href,'matiere_edit?')]")
matIsPresent = False matIsPresent = False
for element in elements: for element in elements:
@ -162,17 +169,17 @@ class PythonOrgSearch(unittest.TestCase):
# @Expected : Le semestre est créé et il apparait désormais dans la table des formations # @Expected : Le semestre est créé et il apparait désormais dans la table des formations
def test_016_ajout_Semestre(self): def test_016_ajout_Semestre(self):
driver = self.driver driver = self.driver
global URL wait = self.wait
driver.get(URL) driver.get(URL)
idAddSemestre = "add-semestre-" + ACRONYME_FORMATION.replace(" ", "-") idAddSemestre = "add-semestre-" + ACRONYME_FORMATION.lower().replace(" ", "-")
driver.find_element_by_id(idAddSemestre).click() driver.find_element_by_id(idAddSemestre).click()
self.wait.until(EC.url_changes(URL)) wait.until(EC.url_changes(URL))
driver.find_element_by_name("date_debut").send_keys("01/01/2021") driver.find_element_by_name("date_debut").send_keys("01/01/2021")
driver.find_element_by_name("date_fin").send_keys("30/06/2021") driver.find_element_by_name("date_fin").send_keys("30/06/2021")
driver.find_element_by_name("responsable_id").send_keys("BACH Test (Bach)") driver.find_element_by_name("responsable_id").send_keys("HAUSPIE Michael (bach)")
Select(driver.find_element_by_id("tf_semestre_id")).select_by_value("4") Select(driver.find_element_by_id("tf_semestre_id")).select_by_value("4")
driver.find_element_by_id("tf_submit").click() driver.find_element_by_id("tf_submit").click()
self.wait.until(EC.url_changes(URL)) wait.until(EC.url_changes(URL))
self.assertTrue( self.assertTrue(
"Nouveau semestre créé" "Nouveau semestre créé"
in driver.find_element_by_class_name("head_message").text in driver.find_element_by_class_name("head_message").text
@ -185,62 +192,62 @@ class PythonOrgSearch(unittest.TestCase):
# @expected : La formation est dupliquée et à la version "2" # @expected : La formation est dupliquée et à la version "2"
def test_017_creer_nouvelle_version_formation(self): def test_017_creer_nouvelle_version_formation(self):
driver = self.driver driver = self.driver
global URL wait = self.wait
driver.get(URL) driver.get(URL)
idTitre = "titre-" + ACRONYME_FORMATION idTitre = "titre-" + ACRONYME_FORMATION
driver.find_element_by_id(idTitre).click() driver.find_element_by_id(idTitre).click()
self.wait.until(EC.url_changes(URL)) wait.until(EC.url_changes(URL))
tmpurl = driver.current_url tmpurl = driver.current_url
driver.find_element_by_xpath( driver.find_element_by_xpath(
"//a[contains(@href,'formation_create_new_version?')]" "//a[contains(@href,'formation_create_new_version?')]"
).click() ).click()
self.wait.until(EC.url_changes(tmpurl)) wait.until(EC.url_changes(tmpurl))
self.assertTrue("Nouvelle version !" in driver.page_source) self.assertTrue("Nouvelle version !" in driver.page_source)
driver.get(URL) driver.get(URL)
elements = driver.find_elements_by_class_name("version") elements = driver.find_elements_by_class_name("version")
versionIsPresent = False version_is_present = False
for element in elements: for element in elements:
if element.text == "2": if element.text == "2":
versionIsPresent = True version_is_present = True
self.assertTrue(versionIsPresent) self.assertTrue(version_is_present)
# Test : Supprime une formation après avoir supprimé les semestres qui y sont rattachés # Test : Supprime une formation après avoir supprimé les semestres qui y sont rattachés
# @expected : La formation n'apparait plus dans le tableau des formations # @expected : La formation n'apparait plus dans le tableau des formations
def test_020_delete_formation(self): def test_020_delete_formation(self):
driver = self.driver driver = self.driver
global URL wait = self.wait
driver.get(URL) driver.get(URL)
idButtonDelete = "delete-formation-" + ACRONYME_FORMATION id_button_delete = "delete-formation-" + ACRONYME_FORMATION
driver.find_element_by_id(idButtonDelete).click() driver.find_element_by_id(id_button_delete).click()
self.wait.until(EC.url_changes(URL)) wait.until(EC.url_changes(URL))
tmpURLDelete = driver.current_url tmp_url_delete = driver.current_url
listeSemestres = driver.find_elements_by_xpath( liste_semestres = driver.find_elements_by_xpath(
"//a[contains(@href, 'formsemestre_status?')]" "//a[contains(@href, 'formsemestre_status?')]"
) )
for semestre in listeSemestres: for semestre in liste_semestres:
semestre.click() semestre.click()
self.wait.until(EC.url_changes(URL)) wait.until(EC.url_changes(URL))
driver.find_element_by_xpath( driver.find_element_by_xpath(
"(//a[contains(text(),'Semestre')])[2]" "(//a[contains(text(),'Semestre')])[2]"
).click() ).click()
driver.find_element_by_xpath( driver.find_element_by_xpath(
"//a[contains(@href, 'formsemestre_delete?')]" "//a[contains(@href, 'formsemestre_delete?')]"
).click() ).click()
self.wait.until(EC.url_changes(URL)) wait.until(EC.url_changes(URL))
driver.find_element_by_id("tf_submit").click() driver.find_element_by_id("tf_submit").click()
time.sleep(2) time.sleep(2)
driver.find_element_by_xpath("//input[@value='OK']").click() driver.find_element_by_xpath("//input[@value='OK']").click()
driver.get(tmpURLDelete) driver.get(tmp_url_delete)
driver.find_element_by_xpath( driver.find_element_by_xpath(
"//input[@value='Supprimer cette formation']" "//input[@value='Supprimer cette formation']"
).click() ).click()
driver.get(URL) driver.get(URL)
formations = driver.find_elements_by_class_name("version") formations = driver.find_elements_by_class_name("version")
formationDelete = True formation_delete = True
for formation in formations: for formation in formations:
if "1" in formation.text: if "1" in formation.text:
formationDelete = False formation_delete = False
self.assertTrue(formationDelete) self.assertTrue(formation_delete)
# def test_create_module(self): # def test_create_module(self):
# driver = self.driver # driver = self.driver

View File

@ -21,27 +21,26 @@ from selenium.webdriver.common.keys import Keys
from selenium.webdriver.support.ui import Select from selenium.webdriver.support.ui import Select
from selenium.webdriver.support.select import Select from selenium.webdriver.support.select import Select
URL = SCHEMA + "://" + BASE_URL + NOM_DPT + "/Scolarite" URL_ROOT = SCHEMA + "://" + BASE_URL
URL_AUTH = "/".join((URL_ROOT, "auth", "login"))
URL_SCODOC8 = "/".join((URL_ROOT, "index"))
URL_HOME = "/".join((URL_ROOT, "ScoDoc", "index"))
URL_DEPT = "/".join((URL_ROOT, "ScoDoc", NOM_DPT, "Scolarite", "index_html"))
URL_ADMIN = "/".join((URL_ROOT, "ScoDoc", "admin"))
ACRONYME_FORMATION = "FormationTEST" ACRONYME_FORMATION = "FormationTEST"
def main(): def main():
next_page = URL_HOME
if NAVIGATEUR == "firefox": if NAVIGATEUR == "firefox":
driver = webdriver.Firefox() driver = webdriver.Firefox()
else: else:
driver = webdriver.Chrome() driver = webdriver.Chrome()
driver.get( auth_page = URL_AUTH + ("?next=" + next_page).replace("/", "%2F")
SCHEMA driver.get(auth_page)
+ "://" driver.find_element_by_id("user_name").send_keys(SCODOC_ADMIN_ID)
+ SCODOC_ADMIN_ID driver.find_element_by_id("password").send_keys(SCODOC_ADMIN_PASS)
+ ":" driver.find_element_by_id("submit").click()
+ SCODOC_ADMIN_PASS
+ "@"
+ BASE_SSH_URL
+ "force_admin_authentication"
)
driver.get(SCHEMA + "://" + BASE_URL + "scodoc_admin")
time.sleep(2) time.sleep(2)
try: try:
select = Select(driver.find_element_by_id("create-dept")) select = Select(driver.find_element_by_id("create-dept"))