Example #1
0
    def test_vacations_update_first_by_admin(self):
        self.login_admin()

        response = \
            self.client.put(APIUrl.vacations_id(self.user_vacation.id), {
                'user': self.user_vacation.user_id,
                'date_start': self.get_date(),
                'date_end': self.get_date(bigger=14),
                'comment_user': '******',
                'comment_admin': 'comment_new',
                'state': Vacation.VACATION_APPROVED_BY_ADMIN
            })

        self.assertEqual(response.status_code, status.HTTP_200_OK)
        self.assertEqual(response.data['state'],
                         Vacation.VACATION_APPROVED_BY_ADMIN)

        response = \
            self.client.put(APIUrl.vacations_id(self.other_user_vacation.id), {
                'user': self.other_user_vacation.user_id,
                'date_start': self.get_date(),
                'date_end': self.get_date(bigger=14),
                'comment_user': '******',
                'comment_admin': 'comment_new',
                'state': Vacation.VACATION_REJECTED_BY_ADMIN
            })

        self.assertEqual(response.status_code, status.HTTP_200_OK)
        self.assertEqual(response.data['state'],
                         Vacation.VACATION_REJECTED_BY_ADMIN)
Example #2
0
    def test_vacations_unknown_CRUD(self):
        # Create
        response = self.client.post(
            APIUrl.vacations, {
                'user': 2,
                'date_start': self.get_date(),
                'date_end': self.get_date(bigger=13),
                'comment_user': '******',
                'comment_admin': 'comment',
                'state': 1
            })
        self.assertEqual(response.status_code, status.HTTP_401_UNAUTHORIZED)

        # Retrieve
        response = \
            self.client.get(APIUrl.vacations_id(self.user_vacation.id))
        self.assertEqual(response.status_code, status.HTTP_401_UNAUTHORIZED)

        # Update
        response = \
            self.client.put(APIUrl.vacations_id(self.user_vacation.id))
        self.assertEqual(response.status_code, status.HTTP_401_UNAUTHORIZED)

        # Delete
        response = \
            self.client.delete(APIUrl.vacations_id(self.user_vacation.id))
        self.assertEqual(response.status_code, status.HTTP_401_UNAUTHORIZED)
Example #3
0
    def test_vacations_unknown_CRUD(self):
        # Create
        response = self.client.post(APIUrl.vacations, {
            'user': 2,
            'date_start': self.get_date(),
            'date_end': self.get_date(bigger=13),
            'comment_user': '******',
            'comment_admin': 'comment',
            'state': 1
        })
        self.assertEqual(response.status_code, status.HTTP_401_UNAUTHORIZED)

        # Retrieve
        response = \
            self.client.get(APIUrl.vacations_id(self.user_vacation.id))
        self.assertEqual(response.status_code, status.HTTP_401_UNAUTHORIZED)

        # Update
        response = \
            self.client.put(APIUrl.vacations_id(self.user_vacation.id))
        self.assertEqual(response.status_code, status.HTTP_401_UNAUTHORIZED)

        # Delete
        response = \
            self.client.delete(APIUrl.vacations_id(self.user_vacation.id))
        self.assertEqual(response.status_code, status.HTTP_401_UNAUTHORIZED)
Example #4
0
    def test_vacations_update_first_by_admin(self):
        self.login_admin()

        response = \
            self.client.put(APIUrl.vacations_id(self.user_vacation.id), {
                'user': self.user_vacation.user_id,
                'date_start': self.get_date(),
                'date_end': self.get_date(bigger=14),
                'comment_user': '******',
                'comment_admin': 'comment_new',
                'state': Vacation.VACATION_APPROVED_BY_ADMIN
            })

        self.assertEqual(response.status_code, status.HTTP_200_OK)
        self.assertEqual(response.data['state'],
                         Vacation.VACATION_APPROVED_BY_ADMIN)

        response = \
            self.client.put(APIUrl.vacations_id(self.other_user_vacation.id), {
                'user': self.other_user_vacation.user_id,
                'date_start': self.get_date(),
                'date_end': self.get_date(bigger=14),
                'comment_user': '******',
                'comment_admin': 'comment_new',
                'state': Vacation.VACATION_REJECTED_BY_ADMIN
            })

        self.assertEqual(response.status_code, status.HTTP_200_OK)
        self.assertEqual(response.data['state'],
                         Vacation.VACATION_REJECTED_BY_ADMIN)
Example #5
0
    def test_users_user_delete(self):
        self.login_user()
        users = Employee.objects.all()
        for user in users:
            response = self.client.delete(APIUrl.users_id(user.id))

            self.assertEqual(response.status_code, status.HTTP_404_NOT_FOUND)
Example #6
0
    def test_users_unknown_delete(self):
        users = Employee.objects.all()
        for user in users:
            response = self.client.delete(APIUrl.users_id(user.id))

            self.assertEqual(response.status_code,
                             status.HTTP_401_UNAUTHORIZED)
Example #7
0
    def test_users_unknown_delete(self):
        users = Employee.objects.all()
        for user in users:
            response = self.client.delete(APIUrl.users_id(user.id))

            self.assertEqual(response.status_code,
                             status.HTTP_401_UNAUTHORIZED)
Example #8
0
    def test_users_user_delete(self):
        self.login_user()
        users = Employee.objects.all()
        for user in users:
            response = self.client.delete(APIUrl.users_id(user.id))

            self.assertEqual(response.status_code,
                             status.HTTP_404_NOT_FOUND)
Example #9
0
    def test_users_user_retrieve_self(self):
        login_user = self.login_user()
        response = self.client.get(APIUrl.users_id(login_user.id))

        data = {key: login_user.__getattribute__(key)
                for key in response.data.keys()}

        self.assertEqual(response.status_code, status.HTTP_200_OK)
        self.assertEqual(response.data, data)
Example #10
0
    def test_vacations_update_second_by_manager(self):
        self.login_manager()

        self.user_vacation.state = Vacation.VACATION_APPROVED_BY_MANAGER
        self.user_vacation.save()

        self.other_user_vacation.state = Vacation.VACATION_REJECTED_BY_MANAGER
        self.other_user_vacation.save()

        for vacation in [self.user_vacation, self.other_user_vacation]:
            for state in Vacation.VACATIONS_STATES:
                response = \
                    self.client.put(APIUrl.vacations_id(vacation.id), {
                        'user': vacation.user.id,
                        'date_start': self.get_date(),
                        'date_end': self.get_date(bigger=14),
                        'comment_user': '******',
                        'comment_admin': 'comment_manager',
                        'state': state[0]
                    })

                self.assertEqual(response.status_code,
                                 status.HTTP_400_BAD_REQUEST)

        self.user_vacation.state = Vacation.VACATION_APPROVED_BY_ADMIN
        self.user_vacation.save()

        self.other_user_vacation.state = Vacation.VACATION_REJECTED_BY_ADMIN
        self.other_user_vacation.save()

        for vacation in [self.user_vacation, self.other_user_vacation]:
            for state in Vacation.VACATIONS_STATES:
                response = \
                    self.client.put(APIUrl.vacations_id(vacation.id), {
                        'user': vacation.user.id,
                        'date_start': self.get_date(),
                        'date_end': self.get_date(bigger=14),
                        'comment_user': '******',
                        'comment_admin': 'comment_manager',
                        'state': state[0]
                    })

                self.assertEqual(response.status_code,
                                 status.HTTP_400_BAD_REQUEST)
Example #11
0
    def test_vacations_update_second_by_manager(self):
        self.login_manager()

        self.user_vacation.state = Vacation.VACATION_APPROVED_BY_MANAGER
        self.user_vacation.save()

        self.other_user_vacation.state = Vacation.VACATION_REJECTED_BY_MANAGER
        self.other_user_vacation.save()

        for vacation in [self.user_vacation, self.other_user_vacation]:
            for state in Vacation.VACATIONS_STATES:
                response = \
                    self.client.put(APIUrl.vacations_id(vacation.id), {
                        'user': vacation.user.id,
                        'date_start': self.get_date(),
                        'date_end': self.get_date(bigger=14),
                        'comment_user': '******',
                        'comment_admin': 'comment_manager',
                        'state': state[0]
                    })

                self.assertEqual(response.status_code,
                                 status.HTTP_400_BAD_REQUEST)

        self.user_vacation.state = Vacation.VACATION_APPROVED_BY_ADMIN
        self.user_vacation.save()

        self.other_user_vacation.state = Vacation.VACATION_REJECTED_BY_ADMIN
        self.other_user_vacation.save()

        for vacation in [self.user_vacation, self.other_user_vacation]:
            for state in Vacation.VACATIONS_STATES:
                response = \
                    self.client.put(APIUrl.vacations_id(vacation.id), {
                        'user': vacation.user.id,
                        'date_start': self.get_date(),
                        'date_end': self.get_date(bigger=14),
                        'comment_user': '******',
                        'comment_admin': 'comment_manager',
                        'state': state[0]
                    })

                self.assertEqual(response.status_code,
                                 status.HTTP_400_BAD_REQUEST)
Example #12
0
    def test_vacations_retrieve_by_admin_manager(self):
        for user in [self.mger, self.admin]:
            self.login_e(user)

            for vacation in [self.user_vacation, self.other_user_vacation]:
                response = self.client.get(APIUrl.vacations_id(vacation.id))

                self.assertEqual(response.status_code, status.HTTP_200_OK)

            self.logout_e()
Example #13
0
    def test_users_user_retrieve_other(self):
        login_user = self.login_user()
        users = Employee.objects.all()
        for user in users:
            if user.id == login_user.id:
                continue

            response = self.client.get(APIUrl.users_id(user.id))

            self.assertEqual(response.status_code, status.HTTP_404_NOT_FOUND)
Example #14
0
    def test_vacations_update_first_by_manager_APPR_REJ_BY_ADMIN(self):
        self.login_manager()

        response = \
            self.client.put(APIUrl.vacations_id(self.user_vacation.id), {
                'comment_user': '******',
                'comment_admin': 'comment_manager',
                'state': Vacation.VACATION_REJECTED_BY_ADMIN
            })

        self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)

        response = \
            self.client.put(APIUrl.vacations_id(self.user_vacation.id), {
                'comment_user': '******',
                'comment_admin': 'comment_manager',
                'state': Vacation.VACATION_APPROVED_BY_ADMIN
            })

        self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)
Example #15
0
    def test_vacations_delete_by_user_admin_manager(self):
        for user in [self.user, self.mger, self.admin]:
            self.login_e(user)

            response = \
                self.client.delete(APIUrl.vacations_id(self.user_vacation.id))

            self.assertEqual(response.status_code,
                             status.HTTP_405_METHOD_NOT_ALLOWED)

            self.logout_e()
Example #16
0
    def test_vacations_retrieve_by_admin_manager(self):
        for user in [self.mger, self.admin]:
            self.login_e(user)

            for vacation in [self.user_vacation, self.other_user_vacation]:
                response = self.client.get(APIUrl.vacations_id(vacation.id))

                self.assertEqual(response.status_code,
                                 status.HTTP_200_OK)

            self.logout_e()
Example #17
0
    def test_users_user_retrieve_self(self):
        login_user = self.login_user()
        response = self.client.get(APIUrl.users_id(login_user.id))

        data = {
            key: login_user.__getattribute__(key)
            for key in response.data.keys()
        }

        self.assertEqual(response.status_code, status.HTTP_200_OK)
        self.assertEqual(response.data, data)
Example #18
0
    def test_vacations_delete_by_user_admin_manager(self):
        for user in [self.user, self.mger, self.admin]:
            self.login_e(user)

            response = \
                self.client.delete(APIUrl.vacations_id(self.user_vacation.id))

            self.assertEqual(response.status_code,
                             status.HTTP_405_METHOD_NOT_ALLOWED)

            self.logout_e()
Example #19
0
    def test_users_user_retrieve_other(self):
        login_user = self.login_user()
        users = Employee.objects.all()
        for user in users:
            if user.id == login_user.id:
                continue

            response = self.client.get(APIUrl.users_id(user.id))

            self.assertEqual(response.status_code,
                             status.HTTP_404_NOT_FOUND)
Example #20
0
    def test_vacations_update_first_by_manager_APPR_REJ_BY_ADMIN(self):
        self.login_manager()

        response = \
            self.client.put(APIUrl.vacations_id(self.user_vacation.id), {
                'comment_user': '******',
                'comment_admin': 'comment_manager',
                'state': Vacation.VACATION_REJECTED_BY_ADMIN
            })

        self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)

        response = \
            self.client.put(APIUrl.vacations_id(self.user_vacation.id), {
                'comment_user': '******',
                'comment_admin': 'comment_manager',
                'state': Vacation.VACATION_APPROVED_BY_ADMIN
            })

        self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)
Example #21
0
    def test_users_user_update_self(self):
        login_user = self.login_user()
        response = self.client.put(APIUrl.users_id(login_user.id), {
            'username': '******',
            'password': '******',
            'email': '*****@*****.**',
            'rang': 'some',
            'group_code': '2'
        })

        self.assertEqual(response.data['group_code'], login_user.group_code)
        self.assertEqual(response.status_code, status.HTTP_200_OK)
Example #22
0
    def test_users_user_update_self(self):
        login_user = self.login_user()
        response = self.client.put(
            APIUrl.users_id(login_user.id), {
                'username': '******',
                'password': '******',
                'email': '*****@*****.**',
                'rang': 'some',
                'group_code': '2'
            })

        self.assertEqual(response.data['group_code'], login_user.group_code)
        self.assertEqual(response.status_code, status.HTTP_200_OK)
Example #23
0
    def test_users_unknown_update(self):
        users = Employee.objects.all()
        for user in users:
            response = self.client.put(APIUrl.users_id(user.id), {
                'username': '******',
                'password': '******',
                'email': '*****@*****.**',
                'rang': 'some',
                'group_code': '2'
            })

            self.assertEqual(response.status_code,
                             status.HTTP_401_UNAUTHORIZED)
Example #24
0
    def test_other_vacations_update_by_user(self):
        login_user = self.login_user()

        response = \
            self.client.put(APIUrl.vacations_id(self.other_user_vacation.id), {
                'user': login_user.id,
                'date_start': self.get_date(),
                'date_end': self.get_date(bigger=14),
                'comment_user': '******',
                'comment_admin': 'comment_admin',
                'state': 1
            })

        self.assertEqual(response.status_code, status.HTTP_404_NOT_FOUND)
Example #25
0
    def test_other_vacations_update_by_user(self):
        login_user = self.login_user()

        response = \
            self.client.put(APIUrl.vacations_id(self.other_user_vacation.id), {
                'user': login_user.id,
                'date_start': self.get_date(),
                'date_end': self.get_date(bigger=14),
                'comment_user': '******',
                'comment_admin': 'comment_admin',
                'state': 1
            })

        self.assertEqual(response.status_code, status.HTTP_404_NOT_FOUND)
Example #26
0
    def test_users_unknown_update(self):
        users = Employee.objects.all()
        for user in users:
            response = self.client.put(
                APIUrl.users_id(user.id), {
                    'username': '******',
                    'password': '******',
                    'email': '*****@*****.**',
                    'rang': 'some',
                    'group_code': '2'
                })

            self.assertEqual(response.status_code,
                             status.HTTP_401_UNAUTHORIZED)
Example #27
0
    def test_vacations_update_by_manager_REJECTED_AND_APPROVE_MANAGER(self):
        self.login_manager()

        response = \
            self.client.put(APIUrl.vacations_id(self.user_vacation.id), {
                'comment_user': '******',
                'comment_admin': 'comment_manager',
                'state': Vacation.VACATION_REJECTED_BY_MANAGER
            })

        self.assertEqual(response.status_code, status.HTTP_200_OK)
        self.assertEqual(response.data['state'],
                         Vacation.VACATION_REJECTED_BY_MANAGER)

        response = \
            self.client.put(APIUrl.vacations_id(self.other_user_vacation.id), {
                'comment_user': '******',
                'comment_admin': 'comment_manager',
                'state': Vacation.VACATION_APPROVED_BY_MANAGER
            })

        self.assertEqual(response.status_code, status.HTTP_200_OK)
        self.assertEqual(response.data['state'],
                         Vacation.VACATION_APPROVED_BY_MANAGER)
Example #28
0
    def test_vacations_update_by_manager_REJECTED_AND_APPROVE_MANAGER(self):
        self.login_manager()

        response = \
            self.client.put(APIUrl.vacations_id(self.user_vacation.id), {
                'comment_user': '******',
                'comment_admin': 'comment_manager',
                'state': Vacation.VACATION_REJECTED_BY_MANAGER
            })

        self.assertEqual(response.status_code, status.HTTP_200_OK)
        self.assertEqual(response.data['state'],
                         Vacation.VACATION_REJECTED_BY_MANAGER)

        response = \
            self.client.put(APIUrl.vacations_id(self.other_user_vacation.id), {
                'comment_user': '******',
                'comment_admin': 'comment_manager',
                'state': Vacation.VACATION_APPROVED_BY_MANAGER
            })

        self.assertEqual(response.status_code, status.HTTP_200_OK)
        self.assertEqual(response.data['state'],
                         Vacation.VACATION_APPROVED_BY_MANAGER)
Example #29
0
    def test_vacations_update_first_by_admin_wrong(self):
        self.login_admin()

        for state in [Vacation.VACATION_APPROVED_BY_MANAGER,
                      Vacation.VACATION_REJECTED_BY_MANAGER]:
            response = \
                self.client.put(APIUrl.vacations_id(self.user_vacation.id), {
                    'user': self.user_vacation.user_id,
                    'date_start': self.get_date(),
                    'date_end': self.get_date(bigger=14),
                    'comment_user': '******',
                    'comment_admin': 'comment_new',
                    'state': state
                })

            self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)
Example #30
0
    def test_users_user_update_other(self):
        login_user = self.login_user()
        users = Employee.objects.all()
        for user in users:
            if user.id == login_user.id:
                continue

            response = self.client.put(
                APIUrl.users_id(user.id), {
                    'username': '******',
                    'password': '******',
                    'email': '*****@*****.**',
                    'rang': 'some',
                    'group_code': '2'
                })

            self.assertEqual(response.status_code, status.HTTP_404_NOT_FOUND)
Example #31
0
    def test_users_user_update_other(self):
        login_user = self.login_user()
        users = Employee.objects.all()
        for user in users:
            if user.id == login_user.id:
                continue

            response = self.client.put(APIUrl.users_id(user.id), {
                'username': '******',
                'password': '******',
                'email': '*****@*****.**',
                'rang': 'some',
                'group_code': '2'
            })

            self.assertEqual(response.status_code,
                             status.HTTP_404_NOT_FOUND)
Example #32
0
    def test_update_by_manager_permissions(self):
        vacations = Vacation.objects.all()
        for vacation in vacations:
            for state in [Vacation.VACATION_NEW,
                          Vacation.VACATION_APPROVED_BY_ADMIN,
                          Vacation.VACATION_REJECTED_BY_ADMIN]:
                response = self.client.put(APIUrl.vacations_id(vacation.id), {
                    'user': vacation.user.id,
                    'date_start': self.get_date(),
                    'date_end': self.get_date(bigger=14),
                    'comment_user': '******',
                    'comment_admin': 'comment_manager',
                    'state': state
                })

                self.assertEqual(response.status_code,
                                 status.HTTP_401_UNAUTHORIZED)
Example #33
0
    def test_vacations_update_first_by_admin_wrong(self):
        self.login_admin()

        for state in [
                Vacation.VACATION_APPROVED_BY_MANAGER,
                Vacation.VACATION_REJECTED_BY_MANAGER
        ]:
            response = \
                self.client.put(APIUrl.vacations_id(self.user_vacation.id), {
                    'user': self.user_vacation.user_id,
                    'date_start': self.get_date(),
                    'date_end': self.get_date(bigger=14),
                    'comment_user': '******',
                    'comment_admin': 'comment_new',
                    'state': state
                })

            self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)
Example #34
0
    def test_update_by_manager_permissions(self):
        vacations = Vacation.objects.all()
        for vacation in vacations:
            for state in [
                    Vacation.VACATION_NEW, Vacation.VACATION_APPROVED_BY_ADMIN,
                    Vacation.VACATION_REJECTED_BY_ADMIN
            ]:
                response = self.client.put(
                    APIUrl.vacations_id(vacation.id), {
                        'user': vacation.user.id,
                        'date_start': self.get_date(),
                        'date_end': self.get_date(bigger=14),
                        'comment_user': '******',
                        'comment_admin': 'comment_manager',
                        'state': state
                    })

                self.assertEqual(response.status_code,
                                 status.HTTP_401_UNAUTHORIZED)
Example #35
0
 def test_vacations_retrieve_by_user(self):
     self.login_user()
     response = \
         self.client.get(APIUrl.vacations_id(self.user_vacation.id))
     self.assertEqual(response.status_code, status.HTTP_200_OK)
Example #36
0
 def test_vacations_retrieve_by_user(self):
     self.login_user()
     response = \
         self.client.get(APIUrl.vacations_id(self.user_vacation.id))
     self.assertEqual(response.status_code, status.HTTP_200_OK)
Example #37
0
 def test_vacations_other_retrieve_by_user(self):
     self.login_user()
     response = \
         self.client.get(APIUrl.vacations_id(self.other_user_vacation.id))
     self.assertEqual(response.status_code, status.HTTP_404_NOT_FOUND)
Example #38
0
 def test_vacations_other_retrieve_by_user(self):
     self.login_user()
     response = \
         self.client.get(APIUrl.vacations_id(self.other_user_vacation.id))
     self.assertEqual(response.status_code, status.HTTP_404_NOT_FOUND)