From e76a7ab56e36beb0aaede9b34a0d8d18813f55f7 Mon Sep 17 00:00:00 2001 From: Albin Date: Mon, 6 Nov 2023 20:20:43 +0100 Subject: [PATCH 1/4] =?UTF-8?q?feat=20(afup#1110):=20functional=20test=20E?= =?UTF-8?q?space=20membre:=20-=20Pr=C3=A9sence=20AG=20-=20Saisie=20infos?= =?UTF-8?q?=20fiche=20entreprise=20publique?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- db/seeds/GeneralMeetings.php | 15 ++++++++++++-- .../Admin/Events/GestionEvenements.feature | 9 ++++++++- .../GeneralMeetingQuestions.feature | 1 - .../MembersArea/GeneralMeeting.feature | 20 +++++++++++++++++++ .../MembersArea/MemberContact.feature | 20 +++++++++++++++++++ 5 files changed, 61 insertions(+), 4 deletions(-) create mode 100644 tests/behat/features/MembersArea/GeneralMeeting.feature create mode 100644 tests/behat/features/MembersArea/MemberContact.feature diff --git a/db/seeds/GeneralMeetings.php b/db/seeds/GeneralMeetings.php index 690ba2de0..9894ffdaf 100644 --- a/db/seeds/GeneralMeetings.php +++ b/db/seeds/GeneralMeetings.php @@ -6,12 +6,18 @@ class GeneralMeetings extends AbstractSeed { public function run() { + $timestamp = strtotime(date("Y-m-d") . "+2 months"); + // Assemblées générales $data = [ [ 'date' => 1635544800, 'description' => 'Assemblée octobre 2021' ], + [ + 'date' => $timestamp, + 'description' => 'Assemblée dans 2 mois' + ], ]; $table = $this->table('afup_assemblee_generale'); @@ -28,6 +34,11 @@ public function run() 'date' => 1635544800, 'presence' => 1 ], + [ + 'id_personne_physique' => '1', + 'date' => $timestamp, + 'presence' => 1 + ], ]; $table = $this->table('afup_presences_assemblee_generale'); @@ -41,12 +52,12 @@ public function run() // Assemblées générales Questions $data = [ [ - 'date' => 1635544800, + 'date' => $timestamp, 'label' => 'Une 1ère question. Alors d\'accord ?', 'created_at' => '2021-09-01 10:42:42' ], [ - 'date' => 1635544800, + 'date' => $timestamp, 'label' => 'Une autre question pertinente. On vote ?', 'created_at' => '2021-09-12 10:42:42' ], diff --git a/tests/behat/features/Admin/Events/GestionEvenements.feature b/tests/behat/features/Admin/Events/GestionEvenements.feature index f636fc1bc..298473224 100644 --- a/tests/behat/features/Admin/Events/GestionEvenements.feature +++ b/tests/behat/features/Admin/Events/GestionEvenements.feature @@ -114,9 +114,14 @@ Feature: Administration - Évènements - Gestions Évènements And I should see "03/03/2027" And I should see "06/03/2027" - Scenario: Si on tente d'en envoyer un mail de test sans contenu, on a un message d'erreur + @reloadDbWithTestData + @clearEmails + Scenario: Si on tente d'en envoyer un mail de test sans contenu, on a un message d'erreur Given I am logged in as admin and on the Administration When I go to "/pages/administration/index.php?page=forum_gestion&action=modifier&id=1" + And I fill in "mail_inscription_content" with "" + And I press "Soumettre" + When I go to "/pages/administration/index.php?page=forum_gestion&action=modifier&id=1" Then I should see "Modifier un évènement" When I follow "Envoyer un test du mail d'inscription sur bureau@afup.org" Then I should see "Contenu du mail d'inscription non trouvé pour le forum forum" @@ -128,6 +133,8 @@ Feature: Administration - Évènements - Gestions Évènements And I press "Soumettre" Then I should see "Le forum a été modifié" + @reloadDbWithTestData + @clearEmails Scenario: Si on tente d'en envoyer un mail de test avec contenu, le mail est bien envoyé Given I am logged in as admin and on the Administration When I go to "/pages/administration/index.php?page=forum_gestion&action=modifier&id=1" diff --git a/tests/behat/features/Admin/Members/GeneralMeeting/GeneralMeetingQuestions.feature b/tests/behat/features/Admin/Members/GeneralMeeting/GeneralMeetingQuestions.feature index 868e3fb9e..1d509ee64 100644 --- a/tests/behat/features/Admin/Members/GeneralMeeting/GeneralMeetingQuestions.feature +++ b/tests/behat/features/Admin/Members/GeneralMeeting/GeneralMeetingQuestions.feature @@ -12,7 +12,6 @@ Feature: Administration - Partie Assemblée Générale Questions And I follow "Assemblée générale - votes" When I follow "Ajouter" Then the ".content h2" element should contain "Assemblée générale - questions" - Then I should see "Assemblée générale du 30/10/2021" And I fill in "general_meeting_question_form[label]" with "Une super question" And I press "Ajouter cette question" Then I should see "La question a été ajoutée" diff --git a/tests/behat/features/MembersArea/GeneralMeeting.feature b/tests/behat/features/MembersArea/GeneralMeeting.feature new file mode 100644 index 000000000..8f98ff637 --- /dev/null +++ b/tests/behat/features/MembersArea/GeneralMeeting.feature @@ -0,0 +1,20 @@ +Feature: Espace membre, Assemblée Générale + @reloadDbWithTestData + Scenario: Non à jour de cotisation + Given I am logged-in with the user "userexpire" and the password "userexpire" + And I follow "Espace membre" + Then I should see "Espace membre" + When I follow "Indiquer ma présence" + Then I should see "Ma participation à l'Assemblée Générale" + And I should see "Vous ne pourrez donc pas voter lors de cette assemblée générale." + + @reloadDbWithTestData + Scenario: Indiquer présent + Given I am logged-in with the user "paul" and the password "paul" + And I follow "Espace membre" + Then I should see "Espace membre" + When I follow "Indiquer ma présence" + Then I should see "Ma participation à l'Assemblée Générale du" + When I select "2" from "form[presence]" + And I press "Confirmer" + Then I should see "La présence et le pouvoir ont été modifiés" diff --git a/tests/behat/features/MembersArea/MemberContact.feature b/tests/behat/features/MembersArea/MemberContact.feature new file mode 100644 index 000000000..44d2ca779 --- /dev/null +++ b/tests/behat/features/MembersArea/MemberContact.feature @@ -0,0 +1,20 @@ +Feature: Espace membre > Personne physique > Coordonnées + + @reloadDbWithTestData + Scenario: Invitation des membres + Given I am logged-in with the user "paul" and the password "paul" + When I follow "Espace membre" + Then I should see "Espace membre" + And I should see "Antenne la plus proche : Aucune" + When I follow "Modifier les coordonnées" + Then I should see "Mes coordonnées" + When I fill in "contact_details[email]" with "paul.personne2@mycorp.fr" + And I fill in "contact_details[address]" with "Rue du chemin" + And I fill in "contact_details[zipcode]" with "75000" + And I fill in "contact_details[city]" with "Ville" + And I select "FR" from "contact_details[country]" + And I select "bordeaux" from "contact_details[nearest_office]" + When I press "contact_details_save" + Then I should see "Votre compte a été modifié !" + When I follow "Accueil" + And I should see "Antenne la plus proche : Bordeaux" \ No newline at end of file From ea2fc17066ad46ce7f418f1e1ab6586f3a556015 Mon Sep 17 00:00:00 2001 From: Albin Date: Mon, 6 Nov 2023 20:21:15 +0100 Subject: [PATCH 2/4] feat (afup#1110): functional test Planete PHP : - Flux RSS - Listing article --- Makefile | 7 +++--- README.md | 10 +++++--- .../views/site/member/index.html.twig | 3 ++- behat-planete.yml | 16 +++++++++++++ db/seeds/FeedArticle.php | 24 ++++++++++++++++++- docker-compose.yml | 21 ++++++++++++++++ htdocs/pages/planete/app.php | 11 ++++++--- planete/app/config/config_test.yml | 8 +++++-- planete/tests/features/Home.feature | 11 +++++++++ planete/tests/features/Rss.feature | 10 ++++++++ 10 files changed, 108 insertions(+), 13 deletions(-) create mode 100644 behat-planete.yml create mode 100644 planete/tests/features/Home.feature create mode 100644 planete/tests/features/Rss.feature diff --git a/Makefile b/Makefile index e20fc4a70..c41857671 100644 --- a/Makefile +++ b/Makefile @@ -72,10 +72,11 @@ test: test-functional: data config htdocs/uploads - CURRENT_UID=$(CURRENT_UID) docker-compose stop dbtest apachephptest mailcatcher - CURRENT_UID=$(CURRENT_UID) docker-compose up -d dbtest apachephptest mailcatcher + CURRENT_UID=$(CURRENT_UID) docker-compose stop dbtest apachephptest planetetest mailcatcher + CURRENT_UID=$(CURRENT_UID) docker-compose up -d dbtest apachephptest planetetest mailcatcher CURRENT_UID=$(CURRENT_UID) docker-compose run --no-deps --rm cliphp ./bin/behat - CURRENT_UID=$(CURRENT_UID) docker-compose stop dbtest apachephptest mailcatcher + CURRENT_UID=$(CURRENT_UID) docker-compose run --no-deps --rm cliphp ./bin/behat -c behat-planete.yml + CURRENT_UID=$(CURRENT_UID) docker-compose stop dbtest apachephptest planetetest mailcatcher data: mkdir data diff --git a/README.md b/README.md index 24dae15d2..39c05d2c6 100644 --- a/README.md +++ b/README.md @@ -68,12 +68,16 @@ Lancement des tests unitaires : ``` - Une alternative est d'utiliser la commande `make test` qui effectuer la même action. -Lancement des tests unitaires : +Lancement des tests fonctionnels : - Se connecter dans le conteneur php `docker/bin/bash` -- Lancer les tests : +- Lancer les tests pour le site web : ``` ./bin/behat ``` +- Lancer les tests pour le site Planete PHP : +``` + ./bin/behat -c behat-planete.yml +``` - Une alternative est d'utiliser la commande `make test-functional`, attention cette commande arrête les containeurs de tests à la fin de l'exécution de la suite de test. Si par la suite vous souhaitez lancer un test, il faut bien penser à les allumer de nouveau. Dans chacun des cas, il est possible de spécifier un test dans la ligne de commande. Exemple: `./bin/behat tests/behat/features/Admin/AdminFeuilles.feature` @@ -84,7 +88,7 @@ Il est possible de tester les paiements Paybox en environnement de développemen Pour cela, les identifiant, site et rang [de test](https://www.paybox.com/espace-integrateur-documentation/comptes-de-tests/) sont déjà configurés dans le fichier parameters.yml par défaut. Ensuite pour le paiement il faut utiliser ces informations [de carte](https://www.paybox.com/espace-integrateur-documentation/cartes-de-tests/) (celle _"Carte participant au programme 3-D Secure (enrôlée)"_) : -* Numéro de carte : `1111 2222 3333 4444` +* Numéro de carte : `1111222233334444` * Validité : `12/25` * CVV : `123` diff --git a/app/Resources/views/site/member/index.html.twig b/app/Resources/views/site/member/index.html.twig index 7e21a9e6c..440d624f1 100644 --- a/app/Resources/views/site/member/index.html.twig +++ b/app/Resources/views/site/member/index.html.twig @@ -46,7 +46,8 @@ Mes coordonnées : {{ user.label }}
Modifiez votre adresse de facturation et votre adresse email, changez votre mot de passe diff --git a/behat-planete.yml b/behat-planete.yml new file mode 100644 index 000000000..e2f0b67fc --- /dev/null +++ b/behat-planete.yml @@ -0,0 +1,16 @@ +default: + suites: + features: + paths: + - %paths.base%/planete/tests + contexts: + - FeatureContext + - Behat\MinkExtension\Context\MinkContext + extensions: + Behat\MinkExtension: + base_url: 'https://planetetest:80' + sessions: + default: + goutte: + guzzle_parameters: + verify: false diff --git a/db/seeds/FeedArticle.php b/db/seeds/FeedArticle.php index 8db307063..9c90c7d87 100644 --- a/db/seeds/FeedArticle.php +++ b/db/seeds/FeedArticle.php @@ -21,7 +21,7 @@ public function run() $data = [ [ - 'afup_planete_flux_id' => 2, + 'afup_planete_flux_id' => 1, 'clef' => '0482a33e-7370-11ee-b962-0242ac120002', 'titre' => 'Un titre', 'url' => 'https://afup.org/url.html', @@ -31,6 +31,28 @@ public function run() 'contenu' => 'Le contenu du super article', 'etat' => 1 ], + [ + 'afup_planete_flux_id' => 1, + 'clef' => '460d0a22-78bd-11ee-b962-0242ac120002', + 'titre' => 'Un 2e titre', + 'url' => 'https://afup.org/url-2.html', + 'maj' => time(), + 'auteur' => 'Toujours un super auteur', + 'resume' => 'Un article qui déchire', + 'contenu' => 'Le contenu de l\'article qui déchire', + 'etat' => 1 + ], + [ + 'afup_planete_flux_id' => 1, + 'clef' => '4d5cf2e2-78bd-11ee-b962-0242ac120002', + 'titre' => 'Un titre désactivé', + 'url' => 'https://afup.org/url-out.html', + 'maj' => time(), + 'auteur' => 'Un super désactivé', + 'resume' => 'Un super désactivé', + 'contenu' => 'Le contenu du super désactivé', + 'etat' => 0 + ], ]; $table = $this->table('afup_planete_billet'); diff --git a/docker-compose.yml b/docker-compose.yml index ae304f764..c9b033c16 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -89,6 +89,26 @@ services: - db - mailcatcher + planetetest: + build: + context: ./docker/dockerfiles/planete + args: + uid: ${CURRENT_UID:-1001} + gid: "1001" + ENABLE_XDEBUG: ${ENABLE_XDEBUG:-false} + environment: + SYMFONY_ENV: "test" + volumes: + - ./:/var/www/html + healthcheck: + test: ["CMD", "curl", "-f", "https://planetetest:80"] + interval: 30s + timeout: 10s + retries: 5 + depends_on: + dbtest: + condition: service_healthy + cliphp: build: context: ./docker/dockerfiles/apachephp @@ -104,6 +124,7 @@ services: - apachephp - mailcatcher - apachephptest + - planetetest - dbtest command: "false" diff --git a/htdocs/pages/planete/app.php b/htdocs/pages/planete/app.php index 6a86ffd89..4169d0a70 100644 --- a/htdocs/pages/planete/app.php +++ b/htdocs/pages/planete/app.php @@ -13,9 +13,10 @@ } $isDevEnv = isset($_ENV['SYMFONY_ENV']) && $_ENV['SYMFONY_ENV'] == 'dev'; +$isTestEnv = isset($_ENV['SYMFONY_ENV']) && $_ENV['SYMFONY_ENV'] == 'test'; -if ($_SERVER['HTTP_HOST'] === 'afup.dev' || $isDevEnv) { - if (!$isDevEnv +if ($_SERVER['HTTP_HOST'] === 'afup.dev' || $isDevEnv || $isTestEnv) { + if (!($isDevEnv || $isTestEnv) && ( isset($_SERVER['HTTP_CLIENT_IP']) @@ -33,7 +34,11 @@ $loader = require __DIR__.'/../../../vendor/autoload.php'; Debug::enable(); - $kernel = new PlaneteAppKernel('dev', true); + if ($isDevEnv) { + $kernel = new PlaneteAppKernel('dev', true); + } else { + $kernel = new PlaneteAppKernel('test', true); + } } else { /** @var ClassLoader $loader */ $loader = require __DIR__.'/../../../vendor/autoload.php'; diff --git a/planete/app/config/config_test.yml b/planete/app/config/config_test.yml index 2f6d92503..b2daa58a3 100644 --- a/planete/app/config/config_test.yml +++ b/planete/app/config/config_test.yml @@ -12,5 +12,9 @@ web_profiler: toolbar: false intercept_redirects: false -swiftmailer: - disable_delivery: true +parameters: + database_host: dbtest + database_port: 3306 + database_name: web + database_user: afup + database_password: afup diff --git a/planete/tests/features/Home.feature b/planete/tests/features/Home.feature new file mode 100644 index 000000000..beb0bee14 --- /dev/null +++ b/planete/tests/features/Home.feature @@ -0,0 +1,11 @@ +Feature: Planete PHP - Home + + @reloadDbWithTestData + Scenario: On voit bien toute la page + Given I am on the homepage + Then I should see "planete-php.fr" + Then I should see "Un titre" + Then I should see "Un 2e titre" + Then I should see "Envoyez un email avec l'URL du site et du flux à planetephpfr AT afup POINT org" + When I follow "Articles précédents" + Then I should see "Articles précédents Articles suivants" diff --git a/planete/tests/features/Rss.feature b/planete/tests/features/Rss.feature new file mode 100644 index 000000000..9bebcc478 --- /dev/null +++ b/planete/tests/features/Rss.feature @@ -0,0 +1,10 @@ +Feature: Planete PHP - RSS + + @reloadDbWithTestData + Scenario: On accède bien au flux RSS + Given I am on the homepage + When I follow "RSS Feed" + Then the response should contain "planete php fr" + Then the response should contain "Un titre" + Then the response should contain "Un 2e titre" + Then the response should contain "" From 16647b20c758a9871fc746f4bb641683579ce8c2 Mon Sep 17 00:00:00 2001 From: Albin Date: Mon, 6 Nov 2023 20:21:28 +0100 Subject: [PATCH 3/4] feat (afup#1110): functional test Billeterie : - Retour CB Paybox - Achat billet virement - Achat billet tarif membre --- app/Resources/translations/messages.en.yml | 2 +- db/seeds/Event.php | 3 +- db/seeds/EventTarif.php | 2 +- features/bootstrap/FeatureContext.php | 29 ++++++++ htdocs/css/buttons.css | 9 +++ sources/AppBundle/Payment/Paybox.php | 2 +- .../Admin/Events/TokensSponsors.feature | 9 ++- .../features/EventPages/Ticketing.feature | 72 ++++++++++++++++++- .../features/EventPages/TicketingEn.feature | 4 +- tests/units/AppBundle/Payment/Paybox.php | 4 +- 10 files changed, 124 insertions(+), 12 deletions(-) diff --git a/app/Resources/translations/messages.en.yml b/app/Resources/translations/messages.en.yml index 6d5717058..9c8a55591 100644 --- a/app/Resources/translations/messages.en.yml +++ b/app/Resources/translations/messages.en.yml @@ -87,7 +87,7 @@ Language: Language 'Recevoir le dossier': 'Get it' 'Page précédente': 'Previous page' 'Page suivante': 'Next page' -Billetterie: Ticketting +Billetterie: Ticketing 'Vous êtes connecté avec un compte AFUP d''entreprise. Pour acheter des places au tarif AFUP, celles-ci doivent être enregistrées pour les membres de votre adhésion.': 'You are connected with an enterprise membership account. You can only buy tickets for the accounts of your memberships.' 'Vous êtes connecté avec un compte AFUP personnel. Vous pouvez acheter une place au tarif membre pour vous seul.': 'You are connected with a personnal account. You can buy one member ticket for yourself.' 'Attention votre cotisation ne sera plus valable le jour de l''évènement. Vous pouvez commander des billets au tarif AFUP mais vous devrez renouveler votre cotisation pour pouvoir accéder à l''évènement.': 'Please take care of your membership. It won''t be valid at the date of the event. You can order members tickets but you will have to pay your membership fee before the event.' diff --git a/db/seeds/Event.php b/db/seeds/Event.php index 55660b8d6..93aa20476 100644 --- a/db/seeds/Event.php +++ b/db/seeds/Event.php @@ -28,7 +28,8 @@ public function run() 'fr' => 'François le français', 'en' => 'Henri l\'anglais', 'sponsor_management_fr' => '**Sponsors**, venez, vous serez très visible !', - 'sponsor_management_en' => '**Sponsors**, come, you will be very visible!' + 'sponsor_management_en' => '**Sponsors**, come, you will be very visible!', + 'mail_inscription_content' => 'Contenu email', ]), 'date_fin_appel_projet' => $now + $oneMonthInSeconds, 'date_fin_appel_conferencier' => $event - $oneMonthInSeconds * 2, diff --git a/db/seeds/EventTarif.php b/db/seeds/EventTarif.php index f5b8ac686..135613e5f 100644 --- a/db/seeds/EventTarif.php +++ b/db/seeds/EventTarif.php @@ -24,7 +24,7 @@ public function run() [ 'id_tarif' => 3, 'id_event' => Event::ID_FORUM, - 'price' => 150, + 'price' => 15, 'date_start' => '2010-01-01 10:00:00', 'date_end' => '2099-12-31 23:59:59', ], diff --git a/features/bootstrap/FeatureContext.php b/features/bootstrap/FeatureContext.php index 54ff726cc..a4332afac 100644 --- a/features/bootstrap/FeatureContext.php +++ b/features/bootstrap/FeatureContext.php @@ -4,6 +4,7 @@ use Behat\Behat\Hook\Scope\BeforeScenarioScope; use Behat\Gherkin\Node\PyStringNode; use Behat\Gherkin\Node\TableNode; +use Behat\Mink\Exception\ExpectationException; use Behat\MinkExtension\Context\MinkContext; use Symfony\Component\Filesystem\Filesystem; use Symfony\Component\Process\Process; @@ -107,6 +108,34 @@ public function iAmLoggedInWithTheUserAndThePassword($user, $password) $this->minkContext->assertPageContainsText("Espace membre"); } + /** + * @Then I submit the form with name :formName + */ + public function submitFormWithName($formName) + { + $form = $this->minkContext->getSession()->getPage()->find('xpath', "//form[@name='$formName']"); + + if (null === $form) { + throw new ExpectationException(sprintf('The form named "%s" not found', $formName), null); + } + + $form->submit(); + } + + /** + * @Then simulate the Paybox callback + */ + public function simulateThePayboxCallback() + { + $url = $this->minkContext->getSession()->getCurrentUrl(); + $url = str_replace('paybox-redirect', 'paybox-callback', $url); + + $curl = curl_init($url); + curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); + curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false); + curl_exec($curl); + } + /** * @Then The :field field should only contain the follow values :expectedValuesJson */ diff --git a/htdocs/css/buttons.css b/htdocs/css/buttons.css index a2b11c74e..55ab2aa9a 100644 --- a/htdocs/css/buttons.css +++ b/htdocs/css/buttons.css @@ -56,3 +56,12 @@ input[type="submit"].button--call-to-action { font-weight: bold; color: #fff; } + +button[type="submit"].button--call-to-action.paiement { + background-color: #ed0678 !important; + border-color: #ed0678 !important; + font-weight: bold !important; + color: #fff !important; + height: auto !important; +} + diff --git a/sources/AppBundle/Payment/Paybox.php b/sources/AppBundle/Payment/Paybox.php index 0bc951177..796acc814 100644 --- a/sources/AppBundle/Payment/Paybox.php +++ b/sources/AppBundle/Payment/Paybox.php @@ -97,7 +97,7 @@ public function generate(\DateTimeInterface $now) foreach ($sanitizedInputs as $inputKey => $inputValue) { $htmlForm .= ' ' . PHP_EOL; } - $htmlForm .= ' ' . PHP_EOL; + $htmlForm .= ' ' . PHP_EOL; $htmlForm .= ''; return $htmlForm; diff --git a/tests/behat/features/Admin/Events/TokensSponsors.feature b/tests/behat/features/Admin/Events/TokensSponsors.feature index 4d098bf9f..efc192f6a 100644 --- a/tests/behat/features/Admin/Events/TokensSponsors.feature +++ b/tests/behat/features/Admin/Events/TokensSponsors.feature @@ -40,6 +40,9 @@ Feature: Administration - Évènements - Tokens Sponsors Then I follow "Envoyer le mail de rappel" And I should see "1 mails de relance ont été envoyés" And I should only receive the following emails: - | to | subject | - | | Toutes les informations concernant votre sponsoring du forum | - | | Sponsor: enregistrez-vous pour le forum | + | to | subject | + | | Toutes les informations concernant votre sponsoring du forum | + | | [forum] Merci ! | + | | [forum] Merci ! | + | | Sponsor: enregistrez-vous pour le forum | + diff --git a/tests/behat/features/EventPages/Ticketing.feature b/tests/behat/features/EventPages/Ticketing.feature index da2442367..88ce6f3f3 100644 --- a/tests/behat/features/EventPages/Ticketing.feature +++ b/tests/behat/features/EventPages/Ticketing.feature @@ -1,10 +1,13 @@ Feature: Event pages - Ticketing @reloadDbWithTestData - Scenario: On voit bien toute la page, même le footer + @clearEmails + Scenario: Achat de billet CB Given I am on "/event/forum/tickets" Then I should see "Billetterie: forum" And I should see "Si vous rencontrez le moindre problème, n'hésitez pas à nous contacter à l'adresse bonjour [@] afup.org." + # Choix du règlement par CB + And I select "0" from "purchase[paymentType]" Then The "purchase[tickets][0][civility]" field should only contain the follow values '["M.", "Mme"]' When I fill in "purchase[tickets][0][firstname]" with "Prénom personne 1" And I fill in "purchase[tickets][0][lastname]" with "Nom personne 1" @@ -16,8 +19,75 @@ Feature: Event pages - Ticketing And I fill in "purchase[city]" with "PARIS" And I fill in "purchase[email]" with "facturationEntreprise@yahoo.fr" And I check "purchase[cgv]" + # Formule Deuxième journée And I select "2" from "purchase[tickets][0][ticketEventType]" And I press "Confirmer & Payer" Then I should see "Paiement de vos billets" And I should see "Nous avons bien reçu votre inscription et nous vous en remercions !" And I should see "Vous serez redirigé vers notre partenaire paybox afin de procéder au paiement d'un montant de 250€" + # Bascule vers Paybox + When I press "Régler par carte" + # Pour suivre la redirection POST de Paybox + And I submit the form with name "PAYBOX" + When I fill in "NUMERO_CARTE" with "1111222233334444" + And I select "12" from "MOIS_VALIDITE" + And I select "25" from "AN_VALIDITE" + And I fill in "CVVX" with "123" + And I press "Valider" + Then I should see "PAIEMENT ACCEPTÉ" + When I follow "Retour" + Then I should see "Le paiement de votre commande s'est bien passé, merci." + # Simuler l'appel de callback Paybox + And simulate the Paybox callback + And I should only receive the following emails: + | to | subject | + | , | Facture évènement AFUP | + | | [forum] Merci ! | + + @reloadDbWithTestData + Scenario: Achat de billet virement + Given I am on "/event/forum/tickets" + Then I should see "Billetterie: forum" + And I should see "Si vous rencontrez le moindre problème, n'hésitez pas à nous contacter à l'adresse bonjour [@] afup.org." + # Choix du règlement par virement + And I select "2" from "purchase[paymentType]" + Then The "purchase[tickets][0][civility]" field should only contain the follow values '["M.", "Mme"]' + When I fill in "purchase[tickets][0][firstname]" with "Prénom personne 1" + And I fill in "purchase[tickets][0][lastname]" with "Nom personne 1" + And I fill in "purchase[tickets][0][email]" with "personne1@yahoo.fr" + And I fill in "purchase[firstname]" with "Prénom facturation" + And I fill in "purchase[lastname]" with "Nom facturation" + And I fill in "purchase[address]" with "42 rue de Strasbourg" + And I fill in "purchase[zipcode]" with "75003" + And I fill in "purchase[city]" with "PARIS" + And I fill in "purchase[email]" with "facturationEntreprise@yahoo.fr" + And I check "purchase[cgv]" + # Formule Deuxième journée + And I select "2" from "purchase[tickets][0][ticketEventType]" + When I press "Confirmer & Payer" + Then I should see "Paiement de vos billets" + And I should see "Nous avons bien reçu votre inscription et nous vous en remercions !" + And I should see "Pour les paiements par virement, merci d'envoyer le virement d'un montant de 250€ aux coordonnées suivantes :" + And I should see "Pensez à indiquer dans le libellé du virement la référence suivante:" + + @reloadDbWithTestData + Scenario: Achat de billet tarif membre + Given I am logged-in with the user "paul" and the password "paul" + And I am on "/event/forum/tickets" + Then I should see "Billetterie: forum" + # Formule Tarif membre + And I select "0" from "purchase[tickets][0][ticketEventType]" + Then The "purchase[tickets][0][civility]" field should only contain the follow values '["M.", "Mme"]' + When I fill in "purchase[tickets][0][firstname]" with "Prénom personne 1" + And I fill in "purchase[tickets][0][lastname]" with "Nom personne 1" + And I fill in "purchase[tickets][0][email]" with "paul.personne@mycorp.fr" + And I fill in "purchase[firstname]" with "Prénom facturation" + And I fill in "purchase[lastname]" with "Nom facturation" + And I fill in "purchase[address]" with "42 rue de Strasbourg" + And I fill in "purchase[zipcode]" with "75003" + And I fill in "purchase[city]" with "PARIS" + And I fill in "purchase[email]" with "facturationEntreprise@yahoo.fr" + And I check "purchase[cgv]" + When I press "Confirmer & Payer" + Then I should see "Paiement de vos billets" + And I should see "Vous serez redirigé vers notre partenaire paybox afin de procéder au paiement d'un montant de 15€" diff --git a/tests/behat/features/EventPages/TicketingEn.feature b/tests/behat/features/EventPages/TicketingEn.feature index 5b57086ef..5fbc7d9d4 100644 --- a/tests/behat/features/EventPages/TicketingEn.feature +++ b/tests/behat/features/EventPages/TicketingEn.feature @@ -1,7 +1,7 @@ Feature: Event pages - Ticketing - en anglais @reloadDbWithTestData - Scenario: On voit bien toute la page, même le footer + Scenario: Achat de billet en anglais Given I am on "/event/forum/tickets?_locale=en" - Then I should see "Ticketting: forum" + Then I should see "Ticketing: forum" Then The "purchase[tickets][0][civility]" field should only contain the follow values '["M.", "Mrs."]' diff --git a/tests/units/AppBundle/Payment/Paybox.php b/tests/units/AppBundle/Payment/Paybox.php index 2765bd0bc..b678e192d 100644 --- a/tests/units/AppBundle/Payment/Paybox.php +++ b/tests/units/AppBundle/Payment/Paybox.php @@ -40,7 +40,7 @@ protected function generateDateProvider() - + EOF; @@ -65,7 +65,7 @@ protected function generateDateProvider() - + EOF; From f4dcc54803b310d734ba0fe9e26de8d1ffc31c83 Mon Sep 17 00:00:00 2001 From: Albin Date: Tue, 7 Nov 2023 13:03:55 +0100 Subject: [PATCH 4/4] =?UTF-8?q?feat=20(afup#1110):=20functional=20test=20P?= =?UTF-8?q?rofil=20speaker=20:=20-=20Acc=C3=A8s=20=C3=A0=20la=20page=20-?= =?UTF-8?q?=20Saisie=20des=20infos?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../views/event/speaker/page.html.twig | 6 ++-- .../Security/TestGithubAuthenticator.php | 9 +++++ .../features/EventPages/SpeakerInfos.feature | 33 ++++++++++++++++++ tests/behat/files/test_file2.pdf | Bin 0 -> 7358 bytes 4 files changed, 45 insertions(+), 3 deletions(-) create mode 100644 tests/behat/features/EventPages/SpeakerInfos.feature create mode 100644 tests/behat/files/test_file2.pdf diff --git a/app/Resources/views/event/speaker/page.html.twig b/app/Resources/views/event/speaker/page.html.twig index 975e364ba..6e9ded820 100644 --- a/app/Resources/views/event/speaker/page.html.twig +++ b/app/Resources/views/event/speaker/page.html.twig @@ -111,7 +111,7 @@ {{ form_errors(speakers_contact_form.phone_number) }} - {{ form_widget(speakers_contact_form.submit) }} + {{ form_widget(speakers_contact_form.submit, {attr: {title: "Enregistrer le contact"}}) }}
@@ -150,7 +150,7 @@
- {{ form_widget(speakers_diner_form.submit) }} + {{ form_widget(speakers_diner_form.submit, {attr: {title: "Enregistrer mes préférences pour le restaurant"}}) }}
{{ form_end(speakers_diner_form) }} @@ -196,7 +196,7 @@
- {{ form_widget(hotel_reservation_form.submit) }} + {{ form_widget(hotel_reservation_form.submit, {attr: {title: "Enregistrer les nuitées"}}) }}
{{ form_end(hotel_reservation_form) }} diff --git a/sources/AppBundle/Security/TestGithubAuthenticator.php b/sources/AppBundle/Security/TestGithubAuthenticator.php index 57dccfcf2..41cef4e37 100644 --- a/sources/AppBundle/Security/TestGithubAuthenticator.php +++ b/sources/AppBundle/Security/TestGithubAuthenticator.php @@ -82,6 +82,15 @@ private function getTestUsersDetails() 'avatar_url' => 'http://test2.com', ]; + $testUsers['agallou'] = [ + 'id' => 320372, + 'name' => 'agallou', + 'login' => 'agallou', + 'company' => 'AFUP', + 'html_url' => 'http://test2.com', + 'avatar_url' => 'http://test2.com', + ]; + return $testUsers; } diff --git a/tests/behat/features/EventPages/SpeakerInfos.feature b/tests/behat/features/EventPages/SpeakerInfos.feature new file mode 100644 index 000000000..9f155f3eb --- /dev/null +++ b/tests/behat/features/EventPages/SpeakerInfos.feature @@ -0,0 +1,33 @@ +Feature: Event > Profil speaker + + @reloadDbWithTestData + Scenario: Accès à la page + Given I go to "/event/forum/speaker-infos" + When I follow "Connect as agallou" + Then I should see "Votre conférence" + Then I should see "Nous vous défrayons" + + @reloadDbWithTestData + Scenario: Saisie des infos + Given I go to "/event/forum/speaker-infos" + When I follow "Connect as agallou" + Then I fill in "speakers_contact[phone_number]" with "0123456789" + And I press "Enregistrer le contact" + Then I should see "Informations de contact enregistrées" + + Then I fill in "speakers_diner[will_attend]" with "1" + Then I fill in "speakers_diner[has_special_diet]" with "1" + Then I fill in "speakers_diner[special_diet_description]" with "Je suis végétarien" + And I press "Enregistrer mes préférences pour le restaurant" + Then I should see "Informations sur votre venue au restaurant des speakers enregistrées" + Then I should see "Je suis végétarien" + + When I check "hotel_reservation_nights_0" + And I press "Enregistrer les nuitées" + Then I should see "Informations sur votre venue à l'hôtel enregistrées" + Then the "hotel_reservation_nights_0" checkbox is checked + + When I attach the file "test_file2.pdf" to "speakers_expenses[files][]" + And I press "Ajouter des fichiers" + When I should see "Fichiers ajoutés" + Then I should see "test_file2.pdf" diff --git a/tests/behat/files/test_file2.pdf b/tests/behat/files/test_file2.pdf new file mode 100644 index 0000000000000000000000000000000000000000..d0108c476f7a4574961e5f758cfd3ef57ab28636 GIT binary patch literal 7358 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 Wk%aLe{R*ixQij~F6jIYu2mBB9v