Beispiel #1
0
class TicketsBaseTestCase(LoggedInTestCase):
    """
    Base test case prepares movie and hall instances for test tickets
    """
    def setUp(self) -> None:
        super(TicketsBaseTestCase, self).setUp()
        self.movie = Movie(name='Movie', duration=120, premiere_year=1999)
        self.movie.save()
        self.hall = Hall(name='Hall', rows_count=16, rows_size=20)
        self.hall.save()
        show_time = \
            datetime.datetime(2019, 12, 24, 10, 0, 0, 1, tzinfo=datetime.timezone.utc) + \
            datetime.timedelta(10)
        self.showing = Showing(hall=self.hall,
                               movie=self.movie,
                               date_time=show_time,
                               price='19.99')
        self.showing.save()
        ticket_time = show_time - datetime.timedelta(10)
        self.ticket = Ticket(showing=self.showing,
                             user=self.user,
                             date_time=ticket_time,
                             row_number=1,
                             seat_number=1)
        self.ticket.save()
Beispiel #2
0
class ShowingsBaseTestCase(LoggedInTestCase):
    """
    Base test case prepares movie and hall instances for test showings
    """

    def setUp(self) -> None:
        self.movie = Movie(name='Movie', duration=120, premiere_year=1999)
        self.movie.save()
        self.hall = Hall(name='Hall', rows_count=16, rows_size=20)
        self.hall.save()
        super(ShowingsBaseTestCase, self).setUp()
Beispiel #3
0
    def test_url_movies_detail_positive_delete_admin(self):
        """
        Positive test checks response for admin's DELETE request to /movies/<int:pk>/
        """
        movie = Movie(name='Name', duration=120, premiere_year=1999)
        movie.save()
        pkey = movie.pk
        response = self.client.delete(
            path=reverse('movie-detail', args=[pkey]),
            HTTP_AUTHORIZATION=f'Bearer {self.admin_token}')
        movies = Movie.objects.filter(pk=pkey)

        self.assertEqual(response.status_code, status.HTTP_204_NO_CONTENT)
        self.assertEqual(movies.count(), 0)
Beispiel #4
0
 def test_url_movies_detail_positive_get(self):
     """
     Positive test checks response for GET request to /movies/<int:pk>/
     """
     movie = Movie(name='Test movie', duration=120, premiere_year=2019)
     movie.save()
     expected_response = {
         'id': movie.pk,
         'name': movie.name,
         'duration': movie.duration,
         'premiere_year': movie.premiere_year,
     }
     response = self.client.get(
         path=reverse('movie-detail', args=[movie.pk]))
     self.assertEqual(response.status_code, status.HTTP_200_OK)
     self.assertDictEqual(response.data, expected_response)
Beispiel #5
0
 def test_url_movies_detail_negative_put_unauthorized(self):
     """
     Negative test checks that anonymous users cannot modify movies via PUT requests
     """
     movie = Movie(name='Name', duration=120, premiere_year=1999)
     movie.save()
     input_data = {
         'name': 'Test name',
         'duration': 16,
         'premiere_year': 2005,
     }
     response = self.client.put(path=reverse('movie-detail',
                                             args=[movie.pk]),
                                data=input_data,
                                content_type='application/json')
     self.assertEqual(response.status_code, status.HTTP_401_UNAUTHORIZED)
Beispiel #6
0
    def test_url_movies_detail_negative_patch_incorrect_input(self):
        """
        Negative test checks incorrect input while modifying movies
        """
        movie = Movie(name='Name', duration=120, premiere_year=1999)
        movie.save()

        with self.subTest():
            input_data = {
                'name': '',
                'duration': 120,
                'premiere_year': 2000,
            }
            response = self.client.patch(
                path=reverse('movie-detail', args=[movie.pk]),
                data=input_data,
                content_type='application/json',
                HTTP_AUTHORIZATION=f'Bearer {self.admin_token}')
            self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)

        with self.subTest():
            input_data = {
                'name': 'Name for movie',
                'duration': 0,
                'premiere_year': 2000,
            }
            response = self.client.patch(
                path=reverse('movie-detail', args=[movie.pk]),
                data=input_data,
                content_type='application/json',
                HTTP_AUTHORIZATION=f'Bearer {self.admin_token}')
            self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)

        with self.subTest():
            input_data = {
                'name': 'Name for movie',
                'duration': 20,
                'premiere_year': 1700,
            }
            response = self.client.patch(
                path=reverse('movie-detail', args=[movie.pk]),
                data=input_data,
                content_type='application/json',
                HTTP_AUTHORIZATION=f'Bearer {self.admin_token}')
            self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)
Beispiel #7
0
 def test_url_movies_detail_negative_get_unknown(self):
     """
     Negative test checks 404 status code on /movies/<not existing hall>
     """
     period = [2000, 2001, 2002]
     movies = [
         Movie(name='Name', duration=120, premiere_year=year)
         for year in period
     ]
     Movie.objects.bulk_create(movies)
     pkey = max(movie.pk for movie in Movie.objects.all()) + 1
     response = self.client.get(path=reverse('movie-detail', args=[pkey]))
     self.assertEqual(response.status_code, status.HTTP_404_NOT_FOUND)
Beispiel #8
0
    def test_url_movies_detail_negative_delete_unauthorized(self):
        """
        Negative test checks that anonymous users cannot delete movies
        """
        movie_data = {
            'name': 'Name for movie',
            'duration': 20,
            'premiere_year': 2000,
        }
        movie = Movie(**movie_data)
        movie.save()
        pkey = movie.pk
        response = self.client.delete(
            path=reverse('movie-detail', args=[movie.pk]))

        movies = Movie.objects.filter(pk=pkey)
        self.assertEqual(response.status_code, status.HTTP_401_UNAUTHORIZED)
        self.assertEqual(movies.count(), 1)
        movie = movies[0]
        self.assertEqual(movie.pk, pkey)
        self.assertEqual(movie.name, movie_data['name'])
        self.assertEqual(movie.duration, movie_data['duration'])
        self.assertEqual(movie.premiere_year, movie_data['premiere_year'])
Beispiel #9
0
 def test_url_movies_detail_positive_put_admin(self):
     """
     Positive test checks response for admin's PUT request to /movies/<int:pk>/
     """
     input_data = {
         'name': 'Test name',
         'duration': 120,
         'premiere_year': 1999,
     }
     movie = Movie(name='Name', duration=100)
     movie.save()
     response = self.client.put(
         path=reverse('movie-detail', args=[movie.pk]),
         data=input_data,
         content_type='application/json',
         HTTP_AUTHORIZATION=f'Bearer {self.admin_token}')
     expected_response = {
         'id': movie.pk,
         'name': input_data['name'],
         'duration': input_data['duration'],
         'premiere_year': input_data['premiere_year'],
     }
     self.assertEqual(response.status_code, status.HTTP_200_OK)
     self.assertDictEqual(response.data, expected_response)
Beispiel #10
0
    def test_url_movies_detail_negative_delete_user(self):
        """
        Negative test checks that users cannot delete movies
        """
        movie_data = {
            'name': 'Name for movie',
            'duration': 20,
            'premiere_year': 2000,
        }
        movie = Movie(**movie_data)
        movie.save()
        pkey = movie.pk
        response = self.client.delete(
            path=reverse('movie-detail', args=[movie.pk]),
            HTTP_AUTHORIZATION=f'Bearer {self.user_token}')

        movies = Movie.objects.filter(pk=pkey)
        self.assertEqual(response.status_code, status.HTTP_403_FORBIDDEN)
        self.assertEqual(movies.count(), 1)
        movie = movies[0]
        self.assertEqual(movie.pk, pkey)
        self.assertEqual(movie.name, movie_data['name'])
        self.assertEqual(movie.duration, movie_data['duration'])
        self.assertEqual(movie.premiere_year, movie_data['premiere_year'])
Beispiel #11
0
 def test_url_movie_list_positive_get(self):
     """
     Positive test checks response for GET request to /movies/
     """
     sub_test_parameters = [
         {
             # Unauthorized user
             'path': self.url_list,
         },
         {
             # Authorized user
             'path': self.url_list,
             'HTTP_AUTHORIZATION': f'Bearer {self.user_token}',
         },
         {
             # Admin
             'path': self.url_list,
             'HTTP_AUTHORIZATION': f'Bearer {self.admin_token}',
         },
     ]
     period = [2000, 2001, 2002]
     movies = [
         Movie(name="Name", duration=120, premiere_year=year)
         for year in period
     ]
     Movie.objects.bulk_create(movies)
     expected_response = [{
         'id': movie.pk,
         'name': movie.name,
         'duration': movie.duration,
         'premiere_year': movie.premiere_year,
     } for movie in Movie.objects.all().order_by('-pk')]
     for request_parameter_set in sub_test_parameters:
         with self.subTest(request_parameter_Set=request_parameter_set):
             response = self.client.get(**request_parameter_set)
             self.assertEqual(response.status_code, status.HTTP_200_OK)
             self.assertIsNotNone(response.data.get('results', None))
             for received, expected in zip(response.data['results'],
                                           expected_response):
                 self.assertDictEqual(dict(received), expected)
Beispiel #12
0
 def test_url_movies_detail_negative_patch_user(self):
     """
     Negative test checks that users cannot modify movies via PATCH requests
     """
     movie = Movie(name='Name', duration=120, premiere_year=1999)
     movie.save()
     input_data = {
         'name': 'New name',
     }
     response = self.client.patch(
         path=reverse('movie-detail', args=[movie.pk]),
         data=input_data,
         content_type='application/json',
         HTTP_AUTHORIZATION=f'Bearer {self.user_token}')
     movie.refresh_from_db()
     self.assertEqual(response.status_code, status.HTTP_403_FORBIDDEN)
Beispiel #13
0
 def test_url_movies_detail_positive_patch_admin(self):
     """
     Positive test checks response for admin's PATCH request to /movies/<int:pk>/
     """
     movie = Movie(name='Name', duration=120, premiere_year=1999)
     movie.save()
     input_data = {
         'name': 'New name',
     }
     response = self.client.patch(
         path=reverse('movie-detail', args=[movie.pk]),
         data=input_data,
         content_type='application/json',
         HTTP_AUTHORIZATION=f'Bearer {self.admin_token}')
     movie.refresh_from_db()
     self.assertEqual(response.status_code, status.HTTP_200_OK)
     self.assertEqual(movie.name, input_data['name'])
     self.assertEqual(response.data['name'], input_data['name'])
Beispiel #14
0
 def setUp(self) -> None:
     self.movie = Movie(name='Movie', duration=120, premiere_year=1999)
     self.movie.save()
     self.hall = Hall(name='Hall', rows_count=16, rows_size=20)
     self.hall.save()
     super(ShowingsBaseTestCase, self).setUp()