Beispiel #1
0
    def test_get_all_questions(self):
        """ Ensure getting all questions is working for admin"""
        # By default this user will have id=1. At least 1 user is required to add questions
        add_admin_user('testuser', '*****@*****.**', 'testpass')
        with self.client:
            response_login = self.client.post('/login/login',
                                              data=json.dumps({
                                                  'email':
                                                  '*****@*****.**',
                                                  'password':
                                                  '******'
                                              }),
                                              content_type='application/json')
            token = json.loads(response_login.data.decode())['token']

            # author_id = 1
            add_question()
            add_question(1, 'Testing', 'print("Testing")', 'Testing', 'Easy')

            response = self.client.get(
                '/questions', headers={'Authorization': f'Bearer {token}'})

            data = json.loads(response.data.decode())
            self.assertEqual(response.status_code, 200)
            self.assertEqual(len(data['data']['questions']), 2)
            self.assertIn('test', data['data']['questions'][0]['body'])
            self.assertIn('test', data['data']['questions'][0]['test_code'])
            self.assertIn('Testing', data['data']['questions'][1]['body'])
            self.assertIn('print("Testing")',
                          data['data']['questions'][1]['test_code'])
            self.assertIn('Testing',
                          data['data']['questions'][1]['test_solution'])
            self.assertIn('Easy', data['data']['questions'][1]['difficulty'])
Beispiel #2
0
    def test_delete_user_question(self):
        # user_id = 1
        user = add_user('testuser', '*****@*****.**', 'testpass')
        # author_id = 1
        question = add_question()
        with self.client:
            response_login = self.client.post('/login/login',
                                              data=json.dumps({
                                                  'email':
                                                  '*****@*****.**',
                                                  'password':
                                                  '******'
                                              }),
                                              content_type='application/json')
            token = json.loads(response_login.data.decode())['token']
            get_response = self.client.get(
                f'/questions/{question.id}/user/{user.id}',
                headers={'Authorization': f'Bearer {token}'})
            data = json.loads(get_response.data.decode())
            self.assertEqual(get_response.status_code, 200)
            self.assertIn('test', data['data']['body'])
            self.assertIn('test', data['data']['test_code'])

            delete_response = self.client.delete(
                f'/questions/{question.id}/user/{user.id}',
                headers={'Authorization': f'Bearer {token}'})
            print(delete_response)
            self.assertEqual(delete_response.status_code, 204)
Beispiel #3
0
    def test_update_user_question(self):
        user = add_user('testuser', '*****@*****.**', 'testpass')
        question = add_question()
        with self.client:
            response_login = self.client.post('/login/login',
                                              data=json.dumps({
                                                  'email':
                                                  '*****@*****.**',
                                                  'password':
                                                  '******'
                                              }),
                                              content_type='application/json')
            token = json.loads(response_login.data.decode())['token']
            get_response = self.client.get(
                f'/questions/{question.id}/user/{user.id}',
                headers={'Authorization': f'Bearer {token}'})
            data = json.loads(get_response.data.decode())
            self.assertEqual(get_response.status_code, 200)
            self.assertIn('test', data['data']['body'])
            self.assertIn('test', data['data']['test_code'])

            put_response = self.client.put(
                f'/questions/{question.id}/user/{user.id}',
                data=json.dumps({'body': 'updatedquestionhere'}),
                content_type='application/json',
                headers={'Authorization': f'Bearer {token}'})

            put_data = json.loads(put_response.data.decode())
            self.assertEqual(put_response.status_code, 201)
            self.assertIn('updatedquestionhere', put_data['data']['body'])
            self.assertIn('success', put_data['status'])
Beispiel #4
0
 def test_add_question(self):
     add_user('test', 'test', 'test')
     question = add_question()
     self.assertTrue(question.id)
     self.assertTrue(question.author_id)
     self.assertTrue(question.body)
     self.assertTrue(question.test_code, 'test')
     self.assertTrue(question.test_solution, 'test')
     self.assertTrue(question.difficulty, 'Easy')
Beispiel #5
0
    def test_update_user_question_unauthorized(self):
        # user_id = 1
        user = add_user('testuser', '*****@*****.**', 'testpass')
        # user_id = 2
        user_2 = add_user('test', 'test', 'test')

        # author_id = 1
        question = add_question()

        # author_id = 2
        question_2 = add_question(2)

        with self.client:
            response_login = self.client.post('/login/login',
                                              data=json.dumps({
                                                  'email':
                                                  '*****@*****.**',
                                                  'password':
                                                  '******'
                                              }),
                                              content_type='application/json')
            token = json.loads(response_login.data.decode())['token']
            get_response = self.client.get(
                f'/questions/{question.id}/user/{user.id}',
                headers={'Authorization': f'Bearer {token}'})
            data = json.loads(get_response.data.decode())
            self.assertEqual(get_response.status_code, 200)
            self.assertIn('test', data['data']['body'])
            self.assertIn('test', data['data']['test_code'])

            put_response = self.client.put(
                f'/questions/{question_2.id}/user/{user_2.id}',
                data=json.dumps({'body': 'updatedquestionhere'}),
                content_type='application/json',
                headers={'Authorization': f'Bearer {token}'})

            put_data = json.loads(put_response.data.decode())
            self.assertEqual(put_response.status_code, 403)
            self.assertIn('fail', put_data['status'])
            self.assertIn('You do not have permission to update this question',
                          put_data['message'])
Beispiel #6
0
 def test_get_user_question_noauth(self):
     """ Ensure fails with 401 unauthorized """
     user = add_user('testuser', '*****@*****.**', 'testpass')
     question = add_question()
     with self.client:
         response = self.client.get(
             f'/questions/{question.id}/user/{user.id}',
             headers={'Authorization': 'Bearer fail'})
         data = json.loads(response.data.decode())
         self.assertEqual(response.status_code, 401)
         self.assertIn('fail', data['status'])
         self.assertIn('Unauthorized', data['message'])
Beispiel #7
0
    def test_get_user_questions_list_authenticated(self):
        # user_id = 1
        add_user('testuser', '*****@*****.**', 'testpass')
        # user_id = 2
        add_user('dontshowme', 'dontshowme', 'testpass')
        with self.client:
            response_login = self.client.post('/login/login',
                                              data=json.dumps({
                                                  'email':
                                                  '*****@*****.**',
                                                  'password':
                                                  '******'
                                              }),
                                              content_type='application/json')
            token = json.loads(response_login.data.decode())['token']
            # author_id = 1
            add_question()
            add_question(1, 'Testing', 'print("Testing")', 'Testing', 'Easy')
            add_question(2, 'Testing', 'print("Testing")', 'Testing', 'Easy')

            response = self.client.get(
                '/questions/user',
                headers={'Authorization': f'Bearer {token}'})
            data = json.loads(response.data.decode())
            self.assertEqual(response.status_code, 200)
            self.assertEqual(len(data['data']['questions']), 2)
            self.assertIn('test', data['data']['questions'][0]['body'])
            self.assertIn('test', data['data']['questions'][0]['test_code'])
            self.assertIn('Testing', data['data']['questions'][1]['body'])
            self.assertIn('print("Testing")',
                          data['data']['questions'][1]['test_code'])
            self.assertIn('Testing',
                          data['data']['questions'][1]['test_solution'])
            self.assertIn('Easy', data['data']['questions'][1]['difficulty'])
Beispiel #8
0
    def test_get_user_question(self):
        """ Ensure get authenticated user question works """
        user = add_user('testuser', '*****@*****.**', 'testpass')
        question = add_question()
        with self.client:
            response_login = self.client.post('/login/login',
                                              data=json.dumps({
                                                  'email':
                                                  '*****@*****.**',
                                                  'password':
                                                  '******'
                                              }),
                                              content_type='application/json')
            token = json.loads(response_login.data.decode())['token']

            response = self.client.get(
                f'/questions/{question.id}/user/{user.id}',
                headers={'Authorization': f'Bearer {token}'})
            data = json.loads(response.data.decode())
            self.assertEqual(response.status_code, 200)
            self.assertIn('test', data['data']['body'])
            self.assertIn('test', data['data']['test_code'])
Beispiel #9
0
    def test_get_user_question_incorrect_user(self):
        """ Ensure get wrong user question fails with 403 """
        add_user('testuser', '*****@*****.**', 'testpass')
        question = add_question()
        with self.client:
            response_login = self.client.post('/login/login',
                                              data=json.dumps({
                                                  'email':
                                                  '*****@*****.**',
                                                  'password':
                                                  '******'
                                              }),
                                              content_type='application/json')
            token = json.loads(response_login.data.decode())['token']

            response = self.client.get(
                f'/questions/{question.id}/user/999',
                headers={'Authorization': f'Bearer {token}'})
            data = json.loads(response.data.decode())
            self.assertEqual(response.status_code, 403)
            self.assertIn('fail', data['status'])
            self.assertIn('You do not have permission to view this question',
                          data['message'])