Ajout Formulaire Posts + Species avec authorisation #7
@@ -2,66 +2,86 @@
|
|||||||
|
|
||||||
namespace App\Controller;
|
namespace App\Controller;
|
||||||
|
|
||||||
use App\Repository\PostRepository;
|
|
||||||
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
|
||||||
use Symfony\Component\Routing\Attribute\Route;
|
|
||||||
use Symfony\Component\HttpFoundation\Request;
|
|
||||||
use Symfony\Component\HttpFoundation\Response;
|
|
||||||
use App\Entity\Post;
|
use App\Entity\Post;
|
||||||
use App\Form\PostType;
|
use App\Form\PostType;
|
||||||
|
use App\Repository\PostRepository;
|
||||||
use Doctrine\ORM\EntityManagerInterface;
|
use Doctrine\ORM\EntityManagerInterface;
|
||||||
|
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
||||||
|
use Symfony\Component\HttpFoundation\Request;
|
||||||
|
use Symfony\Component\HttpFoundation\Response;
|
||||||
|
use Symfony\Component\Routing\Attribute\Route;
|
||||||
use Symfony\Component\Security\Http\Attribute\IsGranted;
|
use Symfony\Component\Security\Http\Attribute\IsGranted;
|
||||||
|
|
||||||
|
#[Route('/post')]
|
||||||
class PostController extends AbstractController
|
class PostController extends AbstractController
|
||||||
{
|
{
|
||||||
#[Route('/', name: 'app_posts')]
|
#[Route('/', name: 'app_post_index', methods: ['GET'])]
|
||||||
public function index(PostRepository $repository): Response
|
public function index(PostRepository $postRepository): Response
|
||||||
{
|
{
|
||||||
$posts = $repository->findAll();
|
|
||||||
return $this->render('post/index.html.twig', [
|
return $this->render('post/index.html.twig', [
|
||||||
'posts' => $posts,
|
'posts' => $postRepository->findAll(),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[Route('/posts/add', name: 'app_add_posts')]
|
#[Route('/new', name: 'app_post_new', methods: ['GET', 'POST'])]
|
||||||
#[IsGranted('ROLE_USER', message: 'You must be logged in to access this page.')]
|
#[IsGranted('ROLE_USER', message: 'You must be logged in to access this page.')]
|
||||||
public function new(Request $request, EntityManagerInterface $entityManager): Response
|
public function new(Request $request, EntityManagerInterface $entityManager): Response
|
||||||
{
|
{
|
||||||
$post = new Post();
|
$post = new Post();
|
||||||
|
|
||||||
$form = $this->createForm(PostType::class, $post);
|
$form = $this->createForm(PostType::class, $post);
|
||||||
|
|
||||||
$form->handleRequest($request);
|
$form->handleRequest($request);
|
||||||
|
|
||||||
if ($form->isSubmitted() && $form->isValid()) {
|
if ($form->isSubmitted() && $form->isValid()) {
|
||||||
$post = $form->getData();
|
|
||||||
$post->setPublicationDate(new \DateTimeImmutable("now"));
|
|
||||||
|
|
||||||
$entityManager->persist($post);
|
$entityManager->persist($post);
|
||||||
$entityManager->flush();
|
$entityManager->flush();
|
||||||
|
|
||||||
return $this->redirectToRoute('app_add_posts');
|
return $this->redirectToRoute('app_post_index', [], Response::HTTP_SEE_OTHER);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->render('post/post.html.twig', [
|
return $this->render('post/new.html.twig', [
|
||||||
|
'post' => $post,
|
||||||
'form' => $form,
|
'form' => $form,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[Route('/posts/edit/{id}', name: 'app_edit_post')]
|
#[Route('/{id}', name: 'app_post_show', methods: ['GET'])]
|
||||||
|
public function show(Post $post): Response
|
||||||
|
{
|
||||||
|
return $this->render('post/show.html.twig', [
|
||||||
|
'post' => $post,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[Route('/{id}/edit', name: 'app_post_edit', methods: ['GET', 'POST'])]
|
||||||
#[IsGranted('ROLE_USER', message: 'You must be logged in to access this page.')]
|
#[IsGranted('ROLE_USER', message: 'You must be logged in to access this page.')]
|
||||||
public function edit(Request $request, EntityManagerInterface $entityManager, Post $post): Response
|
public function edit(Request $request, Post $post, EntityManagerInterface $entityManager): Response
|
||||||
{
|
{
|
||||||
$form = $this->createForm(PostType::class, $post);
|
$form = $this->createForm(PostType::class, $post);
|
||||||
$form->handleRequest($request);
|
$form->handleRequest($request);
|
||||||
|
|
||||||
|
if ($form->isSubmitted() && $form->isValid()) {
|
||||||
|
$entityManager->flush();
|
||||||
if ($form->isSubmitted() && $form->isValid()) {
|
if ($form->isSubmitted() && $form->isValid()) {
|
||||||
$entityManager->flush();
|
$entityManager->flush();
|
||||||
|
|
||||||
return $this->redirectToRoute('app_posts');
|
return $this->redirectToRoute('app_post_index', [], Response::HTTP_SEE_OTHER);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->render('post/edit.html.twig', [
|
return $this->render('post/edit.html.twig', [
|
||||||
'form' => $form->createView(),
|
'post' => $post,
|
||||||
|
'form' => $form,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[Route('/{id}', name: 'app_post_delete', methods: ['POST'])]
|
||||||
|
#[IsGranted('ROLE_USER', message: 'You must be logged in to access this page.')]
|
||||||
|
public function delete(Request $request, Post $post, EntityManagerInterface $entityManager): Response
|
||||||
|
{
|
||||||
|
if ($this->isCsrfTokenValid('delete'.$post->getId(), $request->getPayload()->get('_token'))) {
|
||||||
|
$entityManager->remove($post);
|
||||||
|
$entityManager->flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->redirectToRoute('app_post_index', [], Response::HTTP_SEE_OTHER);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -2,37 +2,84 @@
|
|||||||
|
|
||||||
namespace App\Controller;
|
namespace App\Controller;
|
||||||
|
|
||||||
|
use App\Entity\Species;
|
||||||
|
use App\Form\SpeciesType;
|
||||||
|
use App\Repository\SpeciesRepository;
|
||||||
|
use Doctrine\ORM\EntityManagerInterface;
|
||||||
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
||||||
use Symfony\Component\HttpFoundation\Request;
|
use Symfony\Component\HttpFoundation\Request;
|
||||||
use Symfony\Component\HttpFoundation\Response;
|
use Symfony\Component\HttpFoundation\Response;
|
||||||
use App\Entity\Species;
|
|
||||||
use App\Form\SpeciesType;
|
|
||||||
use Doctrine\ORM\EntityManagerInterface;
|
|
||||||
use Symfony\Component\Routing\Attribute\Route;
|
use Symfony\Component\Routing\Attribute\Route;
|
||||||
use Symfony\Component\Security\Http\Attribute\IsGranted;
|
use Symfony\Component\Security\Http\Attribute\IsGranted;
|
||||||
|
|
||||||
|
#[Route('/species')]
|
||||||
class SpeciesController extends AbstractController
|
class SpeciesController extends AbstractController
|
||||||
{
|
{
|
||||||
#[Route('/species/add', name: 'app_add_species')]
|
#[Route('/', name: 'app_species_index', methods: ['GET'])]
|
||||||
|
public function index(SpeciesRepository $speciesRepository): Response
|
||||||
|
{
|
||||||
|
return $this->render('species/index.html.twig', [
|
||||||
|
'species' => $speciesRepository->findAll(),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[Route('/new', name: 'app_species_new', methods: ['GET', 'POST'])]
|
||||||
#[IsGranted('ROLE_USER', message: 'You must be logged in to access this page.')]
|
#[IsGranted('ROLE_USER', message: 'You must be logged in to access this page.')]
|
||||||
public function new(Request $request, EntityManagerInterface $entityManager): Response
|
public function new(Request $request, EntityManagerInterface $entityManager): Response
|
||||||
{
|
{
|
||||||
$species = new Species();
|
$species = new Species();
|
||||||
$form = $this->createForm(SpeciesType::class, $species);
|
$form = $this->createForm(SpeciesType::class, $species);
|
||||||
|
|
||||||
$form->handleRequest($request);
|
$form->handleRequest($request);
|
||||||
if ($form->isSubmitted() && $form->isValid()) {
|
|
||||||
|
|
||||||
$species = $form->getData();
|
if ($form->isSubmitted() && $form->isValid()) {
|
||||||
|
|
||||||
$entityManager->persist($species);
|
$entityManager->persist($species);
|
||||||
$entityManager->flush();
|
$entityManager->flush();
|
||||||
|
|
||||||
return $this->redirectToRoute('app_add_species');
|
return $this->redirectToRoute('app_species_index', [], Response::HTTP_SEE_OTHER);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->render('species/species.html.twig', [
|
return $this->render('species/new.html.twig', [
|
||||||
'form' => $form->createView(),
|
'species' => $species,
|
||||||
|
'form' => $form,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[Route('/{id}', name: 'app_species_show', methods: ['GET'])]
|
||||||
|
public function show(Species $species): Response
|
||||||
|
{
|
||||||
|
return $this->render('species/show.html.twig', [
|
||||||
|
'species' => $species,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[Route('/{id}/edit', name: 'app_species_edit', methods: ['GET', 'POST'])]
|
||||||
|
#[IsGranted('ROLE_USER', message: 'You must be logged in to access this page.')]
|
||||||
|
public function edit(Request $request, Species $species, EntityManagerInterface $entityManager): Response
|
||||||
|
{
|
||||||
|
$form = $this->createForm(SpeciesType::class, $species);
|
||||||
|
$form->handleRequest($request);
|
||||||
|
|
||||||
|
if ($form->isSubmitted() && $form->isValid()) {
|
||||||
|
$entityManager->flush();
|
||||||
|
|
||||||
|
return $this->redirectToRoute('app_species_index', [], Response::HTTP_SEE_OTHER);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->render('species/edit.html.twig', [
|
||||||
|
'species' => $species,
|
||||||
|
'form' => $form,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[Route('/{id}', name: 'app_species_delete', methods: ['POST'])]
|
||||||
|
#[IsGranted('ROLE_USER', message: 'You must be logged in to access this page.')]
|
||||||
|
public function delete(Request $request, Species $species, EntityManagerInterface $entityManager): Response
|
||||||
|
{
|
||||||
|
if ($this->isCsrfTokenValid('delete'.$species->getId(), $request->getPayload()->get('_token'))) {
|
||||||
|
$entityManager->remove($species);
|
||||||
|
$entityManager->flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->redirectToRoute('app_species_index', [], Response::HTTP_SEE_OTHER);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -6,19 +6,16 @@ use App\Entity\Post;
|
|||||||
use App\Entity\Species;
|
use App\Entity\Species;
|
||||||
use Symfony\Bridge\Doctrine\Form\Type\EntityType;
|
use Symfony\Bridge\Doctrine\Form\Type\EntityType;
|
||||||
use Symfony\Component\Form\AbstractType;
|
use Symfony\Component\Form\AbstractType;
|
||||||
use Symfony\Component\Form\Extension\Core\Type\DateTimeType;
|
|
||||||
use Symfony\Component\Form\FormBuilderInterface;
|
use Symfony\Component\Form\FormBuilderInterface;
|
||||||
use Symfony\Component\OptionsResolver\OptionsResolver;
|
use Symfony\Component\OptionsResolver\OptionsResolver;
|
||||||
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
|
|
||||||
|
|
||||||
class PostType extends AbstractType
|
class PostType extends AbstractType
|
||||||
{
|
{
|
||||||
public function buildForm(FormBuilderInterface $builder, array $options): void
|
public function buildForm(FormBuilderInterface $builder, array $options): void
|
||||||
{
|
{
|
||||||
$builder
|
$builder
|
||||||
->add('foundDate', DateTimeType::class, [
|
->add('foundDate', null, [
|
||||||
'widget' => 'single_text',
|
'widget' => 'single_text',
|
||||||
'empty_data' => null,
|
|
||||||
])
|
])
|
||||||
->add('latitude')
|
->add('latitude')
|
||||||
->add('longitude')
|
->add('longitude')
|
||||||
@@ -28,7 +25,7 @@ class PostType extends AbstractType
|
|||||||
'class' => Species::class,
|
'class' => Species::class,
|
||||||
'choice_label' => 'scientific_name',
|
'choice_label' => 'scientific_name',
|
||||||
])
|
])
|
||||||
->add('save', SubmitType::class, ['label' => 'Create Post']);
|
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -6,7 +6,6 @@ use App\Entity\Species;
|
|||||||
use Symfony\Component\Form\AbstractType;
|
use Symfony\Component\Form\AbstractType;
|
||||||
use Symfony\Component\Form\FormBuilderInterface;
|
use Symfony\Component\Form\FormBuilderInterface;
|
||||||
use Symfony\Component\OptionsResolver\OptionsResolver;
|
use Symfony\Component\OptionsResolver\OptionsResolver;
|
||||||
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
|
|
||||||
|
|
||||||
class SpeciesType extends AbstractType
|
class SpeciesType extends AbstractType
|
||||||
{
|
{
|
||||||
@@ -16,7 +15,7 @@ class SpeciesType extends AbstractType
|
|||||||
->add('scientific_name')
|
->add('scientific_name')
|
||||||
->add('vernacular_name')
|
->add('vernacular_name')
|
||||||
->add('region')
|
->add('region')
|
||||||
->add('save', SubmitType::class, ['label' => 'Create Species']);
|
;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function configureOptions(OptionsResolver $resolver): void
|
public function configureOptions(OptionsResolver $resolver): void
|
||||||
|
4
templates/post/_delete_form.html.twig
Normal file
4
templates/post/_delete_form.html.twig
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
<form method="post" action="{{ path('app_post_delete', {'id': post.id}) }}" onsubmit="return confirm('Are you sure you want to delete this item?');">
|
||||||
|
<input type="hidden" name="_token" value="{{ csrf_token('delete' ~ post.id) }}">
|
||||||
|
<button class="btn">Delete</button>
|
||||||
|
</form>
|
4
templates/post/_form.html.twig
Normal file
4
templates/post/_form.html.twig
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
{{ form_start(form) }}
|
||||||
|
{{ form_widget(form) }}
|
||||||
|
<button class="btn">{{ button_label|default('Save') }}</button>
|
||||||
|
{{ form_end(form) }}
|
@@ -5,11 +5,9 @@
|
|||||||
{% block body %}
|
{% block body %}
|
||||||
<h1>Edit Post</h1>
|
<h1>Edit Post</h1>
|
||||||
|
|
||||||
{{ form_start(form) }}
|
{{ include('post/_form.html.twig', {'button_label': 'Update'}) }}
|
||||||
{{ form_widget(form) }}
|
|
||||||
|
|
||||||
<button type="submit" class="btn btn-primary">Save changes</button>
|
<a href="{{ path('app_post_index') }}">back to list</a>
|
||||||
{{ form_end(form) }}
|
|
||||||
|
|
||||||
<a href="{{ path('app_posts') }}" class="btn btn-secondary">Back to posts</a>
|
{{ include('post/_delete_form.html.twig') }}
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
@@ -1,11 +1,45 @@
|
|||||||
{% extends 'base.html.twig' %}
|
{% extends 'base.html.twig' %}
|
||||||
|
|
||||||
{% block title %}Posts!{% endblock %}
|
{% block title %}Post index{% endblock %}
|
||||||
|
|
||||||
{% block body %}
|
{% block body %}
|
||||||
{% for post in posts %}
|
<h1>Post index</h1>
|
||||||
<div class="card">
|
|
||||||
#{{ post.id }} trouvé le {{ post.foundDate | date("d/m/Y \\à H \\h") }}
|
<table class="table">
|
||||||
</div>
|
<thead>
|
||||||
{% endfor %}
|
<tr>
|
||||||
|
<th>Id</th>
|
||||||
|
<th>FoundDate</th>
|
||||||
|
<th>PublicationDate</th>
|
||||||
|
<th>Latitude</th>
|
||||||
|
<th>Longitude</th>
|
||||||
|
<th>Altitude</th>
|
||||||
|
<th>Commentary</th>
|
||||||
|
<th>actions</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
{% for post in posts %}
|
||||||
|
<tr>
|
||||||
|
<td>{{ post.id }}</td>
|
||||||
|
<td>{{ post.foundDate ? post.foundDate|date('Y-m-d H:i:s') : '' }}</td>
|
||||||
|
<td>{{ post.publicationDate ? post.publicationDate|date('Y-m-d H:i:s') : '' }}</td>
|
||||||
|
<td>{{ post.latitude }}</td>
|
||||||
|
<td>{{ post.longitude }}</td>
|
||||||
|
<td>{{ post.altitude }}</td>
|
||||||
|
<td>{{ post.commentary }}</td>
|
||||||
|
<td>
|
||||||
|
<a href="{{ path('app_post_show', {'id': post.id}) }}">show</a>
|
||||||
|
<a href="{{ path('app_post_edit', {'id': post.id}) }}">edit</a>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{% else %}
|
||||||
|
<tr>
|
||||||
|
<td colspan="8">no records found</td>
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<a href="{{ path('app_post_new') }}">Create new</a>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
11
templates/post/new.html.twig
Normal file
11
templates/post/new.html.twig
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
{% extends 'base.html.twig' %}
|
||||||
|
|
||||||
|
{% block title %}New Post{% endblock %}
|
||||||
|
|
||||||
|
{% block body %}
|
||||||
|
<h1>Create new Post</h1>
|
||||||
|
|
||||||
|
{{ include('post/_form.html.twig') }}
|
||||||
|
|
||||||
|
<a href="{{ path('app_post_index') }}">back to list</a>
|
||||||
|
{% endblock %}
|
@@ -1,3 +0,0 @@
|
|||||||
{{ form_start(form, {'attr': {'novalidate': 'novalidate'}}) }}
|
|
||||||
{{ form_widget(form) }}
|
|
||||||
{{ form_end(form) }}
|
|
46
templates/post/show.html.twig
Normal file
46
templates/post/show.html.twig
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
{% extends 'base.html.twig' %}
|
||||||
|
|
||||||
|
{% block title %}Post{% endblock %}
|
||||||
|
|
||||||
|
{% block body %}
|
||||||
|
<h1>Post</h1>
|
||||||
|
|
||||||
|
<table class="table">
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<th>Id</th>
|
||||||
|
<td>{{ post.id }}</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>FoundDate</th>
|
||||||
|
<td>{{ post.foundDate ? post.foundDate|date('Y-m-d H:i:s') : '' }}</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>PublicationDate</th>
|
||||||
|
<td>{{ post.publicationDate ? post.publicationDate|date('Y-m-d H:i:s') : '' }}</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>Latitude</th>
|
||||||
|
<td>{{ post.latitude }}</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>Longitude</th>
|
||||||
|
<td>{{ post.longitude }}</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>Altitude</th>
|
||||||
|
<td>{{ post.altitude }}</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>Commentary</th>
|
||||||
|
<td>{{ post.commentary }}</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<a href="{{ path('app_post_index') }}">back to list</a>
|
||||||
|
|
||||||
|
<a href="{{ path('app_post_edit', {'id': post.id}) }}">edit</a>
|
||||||
|
|
||||||
|
{{ include('post/_delete_form.html.twig') }}
|
||||||
|
{% endblock %}
|
4
templates/species/_delete_form.html.twig
Normal file
4
templates/species/_delete_form.html.twig
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
<form method="post" action="{{ path('app_species_delete', {'id': species.id}) }}" onsubmit="return confirm('Are you sure you want to delete this item?');">
|
||||||
|
<input type="hidden" name="_token" value="{{ csrf_token('delete' ~ species.id) }}">
|
||||||
|
<button class="btn">Delete</button>
|
||||||
|
</form>
|
4
templates/species/_form.html.twig
Normal file
4
templates/species/_form.html.twig
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
{{ form_start(form) }}
|
||||||
|
{{ form_widget(form) }}
|
||||||
|
<button class="btn">{{ button_label|default('Save') }}</button>
|
||||||
|
{{ form_end(form) }}
|
13
templates/species/edit.html.twig
Normal file
13
templates/species/edit.html.twig
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
{% extends 'base.html.twig' %}
|
||||||
|
|
||||||
|
{% block title %}Edit Species{% endblock %}
|
||||||
|
|
||||||
|
{% block body %}
|
||||||
|
<h1>Edit Species</h1>
|
||||||
|
|
||||||
|
{{ include('species/_form.html.twig', {'button_label': 'Update'}) }}
|
||||||
|
|
||||||
|
<a href="{{ path('app_species_index') }}">back to list</a>
|
||||||
|
|
||||||
|
{{ include('species/_delete_form.html.twig') }}
|
||||||
|
{% endblock %}
|
39
templates/species/index.html.twig
Normal file
39
templates/species/index.html.twig
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
{% extends 'base.html.twig' %}
|
||||||
|
|
||||||
|
{% block title %}Species index{% endblock %}
|
||||||
|
|
||||||
|
{% block body %}
|
||||||
|
<h1>Species index</h1>
|
||||||
|
|
||||||
|
<table class="table">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th>Id</th>
|
||||||
|
<th>Scientific_name</th>
|
||||||
|
<th>Vernacular_name</th>
|
||||||
|
<th>Region</th>
|
||||||
|
<th>actions</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
{% for species in species %}
|
||||||
|
<tr>
|
||||||
|
<td>{{ species.id }}</td>
|
||||||
|
<td>{{ species.scientificName }}</td>
|
||||||
|
<td>{{ species.vernacularName }}</td>
|
||||||
|
<td>{{ species.region }}</td>
|
||||||
|
<td>
|
||||||
|
<a href="{{ path('app_species_show', {'id': species.id}) }}">show</a>
|
||||||
|
<a href="{{ path('app_species_edit', {'id': species.id}) }}">edit</a>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{% else %}
|
||||||
|
<tr>
|
||||||
|
<td colspan="5">no records found</td>
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<a href="{{ path('app_species_new') }}">Create new</a>
|
||||||
|
{% endblock %}
|
11
templates/species/new.html.twig
Normal file
11
templates/species/new.html.twig
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
{% extends 'base.html.twig' %}
|
||||||
|
|
||||||
|
{% block title %}New Species{% endblock %}
|
||||||
|
|
||||||
|
{% block body %}
|
||||||
|
<h1>Create new Species</h1>
|
||||||
|
|
||||||
|
{{ include('species/_form.html.twig') }}
|
||||||
|
|
||||||
|
<a href="{{ path('app_species_index') }}">back to list</a>
|
||||||
|
{% endblock %}
|
34
templates/species/show.html.twig
Normal file
34
templates/species/show.html.twig
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
{% extends 'base.html.twig' %}
|
||||||
|
|
||||||
|
{% block title %}Species{% endblock %}
|
||||||
|
|
||||||
|
{% block body %}
|
||||||
|
<h1>Species</h1>
|
||||||
|
|
||||||
|
<table class="table">
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<th>Id</th>
|
||||||
|
<td>{{ species.id }}</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>Scientific_name</th>
|
||||||
|
<td>{{ species.scientificName }}</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>Vernacular_name</th>
|
||||||
|
<td>{{ species.vernacularName }}</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>Region</th>
|
||||||
|
<td>{{ species.region }}</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<a href="{{ path('app_species_index') }}">back to list</a>
|
||||||
|
|
||||||
|
<a href="{{ path('app_species_edit', {'id': species.id}) }}">edit</a>
|
||||||
|
|
||||||
|
{{ include('species/_delete_form.html.twig') }}
|
||||||
|
{% endblock %}
|
@@ -1,3 +0,0 @@
|
|||||||
{{ form_start(form, {'attr': {'novalidate': 'novalidate'}}) }}
|
|
||||||
{{ form_widget(form) }}
|
|
||||||
{{ form_end(form) }}
|
|
142
tests/Controller/PostControllerTest.php
Normal file
142
tests/Controller/PostControllerTest.php
Normal file
@@ -0,0 +1,142 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Test\Controller;
|
||||||
|
|
||||||
|
use App\Entity\Post;
|
||||||
|
use Doctrine\ORM\EntityManagerInterface;
|
||||||
|
use Doctrine\ORM\EntityRepository;
|
||||||
|
use Symfony\Bundle\FrameworkBundle\KernelBrowser;
|
||||||
|
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
|
||||||
|
|
||||||
|
class PostControllerTest extends WebTestCase
|
||||||
|
{
|
||||||
|
private KernelBrowser $client;
|
||||||
|
private EntityManagerInterface $manager;
|
||||||
|
private EntityRepository $repository;
|
||||||
|
private string $path = '/post/';
|
||||||
|
|
||||||
|
protected function setUp(): void
|
||||||
|
{
|
||||||
|
$this->client = static::createClient();
|
||||||
|
$this->manager = static::getContainer()->get('doctrine')->getManager();
|
||||||
|
$this->repository = $this->manager->getRepository(Post::class);
|
||||||
|
|
||||||
|
foreach ($this->repository->findAll() as $object) {
|
||||||
|
$this->manager->remove($object);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->manager->flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testIndex(): void
|
||||||
|
{
|
||||||
|
$crawler = $this->client->request('GET', $this->path);
|
||||||
|
|
||||||
|
self::assertResponseStatusCodeSame(200);
|
||||||
|
self::assertPageTitleContains('Post index');
|
||||||
|
|
||||||
|
// Use the $crawler to perform additional assertions e.g.
|
||||||
|
// self::assertSame('Some text on the page', $crawler->filter('.p')->first());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testNew(): void
|
||||||
|
{
|
||||||
|
$this->markTestIncomplete();
|
||||||
|
$this->client->request('GET', sprintf('%snew', $this->path));
|
||||||
|
|
||||||
|
self::assertResponseStatusCodeSame(200);
|
||||||
|
|
||||||
|
$this->client->submitForm('Save', [
|
||||||
|
'post[foundDate]' => 'Testing',
|
||||||
|
'post[latitude]' => 'Testing',
|
||||||
|
'post[longitude]' => 'Testing',
|
||||||
|
'post[altitude]' => 'Testing',
|
||||||
|
'post[commentary]' => 'Testing',
|
||||||
|
'post[species]' => 'Testing',
|
||||||
|
]);
|
||||||
|
|
||||||
|
self::assertResponseRedirects($this->path);
|
||||||
|
|
||||||
|
self::assertSame(1, $this->repository->count([]));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testShow(): void
|
||||||
|
{
|
||||||
|
$this->markTestIncomplete();
|
||||||
|
$fixture = new Post();
|
||||||
|
$fixture->setFoundDate('My Title');
|
||||||
|
$fixture->setLatitude('My Title');
|
||||||
|
$fixture->setLongitude('My Title');
|
||||||
|
$fixture->setAltitude('My Title');
|
||||||
|
$fixture->setCommentary('My Title');
|
||||||
|
$fixture->setSpecies('My Title');
|
||||||
|
|
||||||
|
$this->manager->persist($fixture);
|
||||||
|
$this->manager->flush();
|
||||||
|
|
||||||
|
$this->client->request('GET', sprintf('%s%s', $this->path, $fixture->getId()));
|
||||||
|
|
||||||
|
self::assertResponseStatusCodeSame(200);
|
||||||
|
self::assertPageTitleContains('Post');
|
||||||
|
|
||||||
|
// Use assertions to check that the properties are properly displayed.
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEdit(): void
|
||||||
|
{
|
||||||
|
$this->markTestIncomplete();
|
||||||
|
$fixture = new Post();
|
||||||
|
$fixture->setFoundDate('Value');
|
||||||
|
$fixture->setLatitude('Value');
|
||||||
|
$fixture->setLongitude('Value');
|
||||||
|
$fixture->setAltitude('Value');
|
||||||
|
$fixture->setCommentary('Value');
|
||||||
|
$fixture->setSpecies('Value');
|
||||||
|
|
||||||
|
$this->manager->persist($fixture);
|
||||||
|
$this->manager->flush();
|
||||||
|
|
||||||
|
$this->client->request('GET', sprintf('%s%s/edit', $this->path, $fixture->getId()));
|
||||||
|
|
||||||
|
$this->client->submitForm('Update', [
|
||||||
|
'post[foundDate]' => 'Something New',
|
||||||
|
'post[latitude]' => 'Something New',
|
||||||
|
'post[longitude]' => 'Something New',
|
||||||
|
'post[altitude]' => 'Something New',
|
||||||
|
'post[commentary]' => 'Something New',
|
||||||
|
'post[species]' => 'Something New',
|
||||||
|
]);
|
||||||
|
|
||||||
|
self::assertResponseRedirects('/post/');
|
||||||
|
|
||||||
|
$fixture = $this->repository->findAll();
|
||||||
|
|
||||||
|
self::assertSame('Something New', $fixture[0]->getFoundDate());
|
||||||
|
self::assertSame('Something New', $fixture[0]->getLatitude());
|
||||||
|
self::assertSame('Something New', $fixture[0]->getLongitude());
|
||||||
|
self::assertSame('Something New', $fixture[0]->getAltitude());
|
||||||
|
self::assertSame('Something New', $fixture[0]->getCommentary());
|
||||||
|
self::assertSame('Something New', $fixture[0]->getSpecies());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testRemove(): void
|
||||||
|
{
|
||||||
|
$this->markTestIncomplete();
|
||||||
|
$fixture = new Post();
|
||||||
|
$fixture->setFoundDate('Value');
|
||||||
|
$fixture->setLatitude('Value');
|
||||||
|
$fixture->setLongitude('Value');
|
||||||
|
$fixture->setAltitude('Value');
|
||||||
|
$fixture->setCommentary('Value');
|
||||||
|
$fixture->setSpecies('Value');
|
||||||
|
|
||||||
|
$this->manager->persist($fixture);
|
||||||
|
$this->manager->flush();
|
||||||
|
|
||||||
|
$this->client->request('GET', sprintf('%s%s', $this->path, $fixture->getId()));
|
||||||
|
$this->client->submitForm('Delete');
|
||||||
|
|
||||||
|
self::assertResponseRedirects('/post/');
|
||||||
|
self::assertSame(0, $this->repository->count([]));
|
||||||
|
}
|
||||||
|
}
|
124
tests/Controller/SpeciesControllerTest.php
Normal file
124
tests/Controller/SpeciesControllerTest.php
Normal file
@@ -0,0 +1,124 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Test\Controller;
|
||||||
|
|
||||||
|
use App\Entity\Species;
|
||||||
|
use Doctrine\ORM\EntityManagerInterface;
|
||||||
|
use Doctrine\ORM\EntityRepository;
|
||||||
|
use Symfony\Bundle\FrameworkBundle\KernelBrowser;
|
||||||
|
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
|
||||||
|
|
||||||
|
class SpeciesControllerTest extends WebTestCase
|
||||||
|
{
|
||||||
|
private KernelBrowser $client;
|
||||||
|
private EntityManagerInterface $manager;
|
||||||
|
private EntityRepository $repository;
|
||||||
|
private string $path = '/species/';
|
||||||
|
|
||||||
|
protected function setUp(): void
|
||||||
|
{
|
||||||
|
$this->client = static::createClient();
|
||||||
|
$this->manager = static::getContainer()->get('doctrine')->getManager();
|
||||||
|
$this->repository = $this->manager->getRepository(Species::class);
|
||||||
|
|
||||||
|
foreach ($this->repository->findAll() as $object) {
|
||||||
|
$this->manager->remove($object);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->manager->flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testIndex(): void
|
||||||
|
{
|
||||||
|
$crawler = $this->client->request('GET', $this->path);
|
||||||
|
|
||||||
|
self::assertResponseStatusCodeSame(200);
|
||||||
|
self::assertPageTitleContains('Species index');
|
||||||
|
|
||||||
|
// Use the $crawler to perform additional assertions e.g.
|
||||||
|
// self::assertSame('Some text on the page', $crawler->filter('.p')->first());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testNew(): void
|
||||||
|
{
|
||||||
|
$this->markTestIncomplete();
|
||||||
|
$this->client->request('GET', sprintf('%snew', $this->path));
|
||||||
|
|
||||||
|
self::assertResponseStatusCodeSame(200);
|
||||||
|
|
||||||
|
$this->client->submitForm('Save', [
|
||||||
|
'species[scientific_name]' => 'Testing',
|
||||||
|
'species[vernacular_name]' => 'Testing',
|
||||||
|
'species[region]' => 'Testing',
|
||||||
|
]);
|
||||||
|
|
||||||
|
self::assertResponseRedirects($this->path);
|
||||||
|
|
||||||
|
self::assertSame(1, $this->repository->count([]));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testShow(): void
|
||||||
|
{
|
||||||
|
$this->markTestIncomplete();
|
||||||
|
$fixture = new Species();
|
||||||
|
$fixture->setScientific_name('My Title');
|
||||||
|
$fixture->setVernacular_name('My Title');
|
||||||
|
$fixture->setRegion('My Title');
|
||||||
|
|
||||||
|
$this->manager->persist($fixture);
|
||||||
|
$this->manager->flush();
|
||||||
|
|
||||||
|
$this->client->request('GET', sprintf('%s%s', $this->path, $fixture->getId()));
|
||||||
|
|
||||||
|
self::assertResponseStatusCodeSame(200);
|
||||||
|
self::assertPageTitleContains('Species');
|
||||||
|
|
||||||
|
// Use assertions to check that the properties are properly displayed.
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEdit(): void
|
||||||
|
{
|
||||||
|
$this->markTestIncomplete();
|
||||||
|
$fixture = new Species();
|
||||||
|
$fixture->setScientific_name('Value');
|
||||||
|
$fixture->setVernacular_name('Value');
|
||||||
|
$fixture->setRegion('Value');
|
||||||
|
|
||||||
|
$this->manager->persist($fixture);
|
||||||
|
$this->manager->flush();
|
||||||
|
|
||||||
|
$this->client->request('GET', sprintf('%s%s/edit', $this->path, $fixture->getId()));
|
||||||
|
|
||||||
|
$this->client->submitForm('Update', [
|
||||||
|
'species[scientific_name]' => 'Something New',
|
||||||
|
'species[vernacular_name]' => 'Something New',
|
||||||
|
'species[region]' => 'Something New',
|
||||||
|
]);
|
||||||
|
|
||||||
|
self::assertResponseRedirects('/species/');
|
||||||
|
|
||||||
|
$fixture = $this->repository->findAll();
|
||||||
|
|
||||||
|
self::assertSame('Something New', $fixture[0]->getScientific_name());
|
||||||
|
self::assertSame('Something New', $fixture[0]->getVernacular_name());
|
||||||
|
self::assertSame('Something New', $fixture[0]->getRegion());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testRemove(): void
|
||||||
|
{
|
||||||
|
$this->markTestIncomplete();
|
||||||
|
$fixture = new Species();
|
||||||
|
$fixture->setScientific_name('Value');
|
||||||
|
$fixture->setVernacular_name('Value');
|
||||||
|
$fixture->setRegion('Value');
|
||||||
|
|
||||||
|
$this->manager->persist($fixture);
|
||||||
|
$this->manager->flush();
|
||||||
|
|
||||||
|
$this->client->request('GET', sprintf('%s%s', $this->path, $fixture->getId()));
|
||||||
|
$this->client->submitForm('Delete');
|
||||||
|
|
||||||
|
self::assertResponseRedirects('/species/');
|
||||||
|
self::assertSame(0, $this->repository->count([]));
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user