def test_delete(self, get_client_db): # DELETE client, _db, headers = get_client_db clear_data(_db) # CENÁRIO 1 - Tentativa com turma não registrada response = client.delete('/turmas/SCC5900/frequencias/1/', headers=headers) assert response.status_code == 400 assert response.json['message'] == 'Não existe turma com esse codigo no banco de dados.' # CENÁRIO 2 - OK _db.session.add(Professor(nome='AAA', departamento='AAA', instituicao='AAA')) _db.session.add(Turma(nome='Metodologia Cientifica', codigo='SCC5900', semestre="2020.2", professor_id=1)) mock_img = from_img_dir_to_bytes('./tests/test_images/ivete.jpg') mock_face = array(process_faces(mock_img)) mock_face_embedding = from_array_to_bytes(mock_face) _db.session.add(Aluno(nome='Ivete', curso='Danca', matricula='101010', embedding=mock_face_embedding)) _db.session.add(Participante(turma_codigo='SCC5900', matricula='101010')) mock_data_img_turma = from_img_dir_to_bytes('./tests/test_images/ivete-e-boy.jpg') _db.session.add(Frequencia(turma_codigo='SCC5900', imagem_turma=mock_data_img_turma)) _db.session.commit() response = client.delete('/turmas/SCC5900/frequencias/1/', headers=headers) assert response.status_code == 204 # CENÁRIO 3 - Tentativa com frequência não mais presente response = client.delete('/turmas/SCC5900/frequencias/1/', headers=headers) assert response.status_code == 400 assert response.json['message'] == 'Não existe frequencia com esse ID no banco de dados.' # CLEAN UP clear_data(_db)
def test_get(self, get_client_db): # GET client, _db, headers = get_client_db clear_data(_db) _db.session.add(Professor(nome='AAA', departamento='AAA', instituicao='AAA')) _db.session.add(Turma(nome='Metodologia Cientifica', codigo='SCC5900', semestre="2020.2", professor_id=1)) mock_img = from_img_dir_to_bytes('./tests/test_images/ivete.jpg') mock_face = array(process_faces(mock_img)) mock_face_embedding = from_array_to_bytes(mock_face) _db.session.add(Aluno(nome='Ivete', curso='Danca', matricula='101010', embedding=mock_face_embedding)) _db.session.add(Participante(turma_codigo='SCC5900', matricula='101010')) mock_data_img_turma = from_img_dir_to_bytes('./tests/test_images/ivete-e-boy.jpg') _db.session.add(Frequencia(turma_codigo='SCC5900', imagem_turma=mock_data_img_turma)) _db.session.add(Presenca(frequencia_id=1, participante_id=1, status=True)) _db.session.add(AnotacaoErros(frequencia_id=1, falsos_positivos=1, falsos_negativos=0)) _db.session.commit() # CENÁRIO 1 - Tentativa com turma não registrada response = client.get('/turmas/FAKECLASS/frequencias/1/erros/', headers=headers) assert response.status_code == 400 assert response.json['message'] == 'Não existe turma com esse codigo no banco de dados.' # CENÁRIO 2 - Tentativa com frequência não registrada response = client.get('/turmas/SCC5900/frequencias/100/erros/', headers=headers) assert response.status_code == 400 assert response.json['message'] == 'Não existe frequencia com esse ID no banco de dados.' # CENÁRIO 3 - OK response = client.get('/turmas/SCC5900/frequencias/1/erros/', headers=headers) assert response.json[0]['frequencia_id'] == 1 assert response.json[0]['falsos_positivos'] == 1 assert response.json[0]['falsos_negativos'] == 0 # CLEAN UP clear_data(_db)
def test_post(self, get_client_db): # POST client, _db, headers = get_client_db clear_data(_db) # CENÁRIO 1 - Tentativa com turma não registrada file = os.path.join("./tests/test_images/ivete-e-boy.jpg") mock_data_img_turma = (file, './tests/test_images/ivete-e-boy.jpg') data = { "imagem_turma": mock_data_img_turma } response = client.post('/turmas/SCC5900/frequencias/', data=data, headers=headers) assert response.status_code == 400 assert response.json['message'] == 'Não existe turma com esse codigo no banco de dados.' # CENÁRIO 2 - Tentativa com turma sem participantes _db.session.add(Professor(nome='AAA', departamento='AAA', instituicao='AAA')) _db.session.add(Turma(nome='Metodologia Cientifica', codigo='SCC5900', semestre="2020.2", professor_id=1)) _db.session.commit() response = client.post('/turmas/SCC5900/frequencias/', data=data, headers=headers) assert response.status_code == 400 assert response.json['message'] == 'Não existem participantes registrados na turma.' # CENÁRIO 3 - OK mock_img = from_img_dir_to_bytes('./tests/test_images/ivete.jpg') mock_face = array(process_faces(mock_img)) mock_face_embedding = from_array_to_bytes(mock_face) _db.session.add(Aluno(nome='Ivete', curso='Danca', matricula='101010', embedding=mock_face_embedding)) _db.session.add(Participante(turma_codigo='SCC5900', matricula='101010')) _db.session.commit() response = client.post('/turmas/SCC5900/frequencias/', data=data, headers=headers) assert response.status_code == 201 assert response.json == {'frequencia.id': 1} # CLEAN UP clear_data(_db)
def test_post(self, get_client_db): # POST client, _db, headers = get_client_db clear_data(_db) _db.session.add( Professor(nome='AAA', departamento='AAA', instituicao='AAA')) _db.session.add( Turma(nome='Metodologia Cientifica', codigo='SCC5900', semestre="2020.2", professor_id=1)) mock_img = from_img_dir_to_bytes('./tests/test_images/ivete.jpg') mock_face = array(process_faces(mock_img)) mock_face_embedding = from_array_to_bytes(mock_face) _db.session.add( Aluno(nome='Ivete', curso='Danca', matricula='101010', embedding=mock_face_embedding)) _db.session.add( Participante(turma_codigo='SCC5900', matricula='101010')) mock_data_img_turma = from_img_dir_to_bytes( './tests/test_images/ivete-e-boy.jpg') _db.session.add( Frequencia(turma_codigo='SCC5900', imagem_turma=mock_data_img_turma)) _db.session.commit() # CENÁRIO 1 - Matrícula inválida data = {"matricula": 101011, "status": True} response = client.post('/turmas/SCC5900/frequencias/1/presencas/', data=data, headers=headers) assert response.status_code == 400 assert response.json[ 'message'] == 'Não existe aluno com essa matricula participando da disciplina no banco de dados.' # CENÁRIO 2 - OK data = {"matricula": 101010, "status": True} response = client.post('/turmas/SCC5900/frequencias/1/presencas/', data=data, headers=headers) assert response.status_code == 201 assert response.json == {'participante.id': 1} # CENÁRIO 3 - Aluno não registrado response = client.post('/turmas/SCC5900/frequencias/1/presencas/', data=data, headers=headers) assert response.status_code == 400 assert response.json[ 'message'] == 'Registro de presença desse aluno já está presente no banco de dados.' # CENÁRIO 4 - Não existe turma com o código indicado response = client.post('/turmas/FAKECLASS/frequencias/1/presencas/', data=data, headers=headers) assert response.status_code == 400 assert response.json[ 'message'] == 'Não existe turma com esse codigo no banco de dados.' # CENÁRIO 5 - Não existe frequencia com o ID indicado response = client.post('/turmas/SCC5900/frequencias/100/presencas/', data=data, headers=headers) assert response.status_code == 400 assert response.json[ 'message'] == 'Não existe frequencia com esse ID no banco de dados.' # CLEAN UP clear_data(_db)
def test_delete(self, get_client_db): # DELETE client, _db, headers = get_client_db clear_data(_db) _db.session.add( Professor(nome='AAA', departamento='AAA', instituicao='AAA')) _db.session.add( Turma(nome='Metodologia Cientifica', codigo='SCC5900', semestre="2020.2", professor_id=1)) mock_img = from_img_dir_to_bytes('./tests/test_images/ivete.jpg') mock_face = array(process_faces(mock_img)) mock_face_embedding = from_array_to_bytes(mock_face) _db.session.add( Aluno(nome='Ivete', curso='Danca', matricula='101010', embedding=mock_face_embedding)) _db.session.add( Participante(turma_codigo='SCC5900', matricula='101010')) mock_data_img_turma = from_img_dir_to_bytes( './tests/test_images/ivete-e-boy.jpg') _db.session.add( Frequencia(turma_codigo='SCC5900', imagem_turma=mock_data_img_turma)) _db.session.add( Presenca(frequencia_id=1, participante_id=1, status=True)) _db.session.add( AnotacaoErros(frequencia_id=1, falsos_positivos=0, falsos_negativos=0)) _db.session.commit() # CENÁRIO 1 - Matrícula inválida data = { "matricula": 202020, } response = client.delete('/turmas/SCC5900/frequencias/1/presencas/', data=data, headers=headers) assert response.status_code == 400 assert response.json[ 'message'] == 'Não existe aluno com essa matricula participando da disciplina no banco de dados.' # CENÁRIO 2 - OK data = { "matricula": 101010, } response = client.delete('/turmas/SCC5900/frequencias/1/presencas/', data=data, headers=headers) assert response.status_code == 204 # CENÁRIO 3 - Não existe turma com o código indicado response = client.delete('/turmas/FAKECLASS/frequencias/1/presencas/', data=data, headers=headers) assert response.status_code == 400 assert response.json[ 'message'] == 'Não existe turma com esse codigo no banco de dados.' # CENÁRIO 4 - Não existe frequencia com o ID indicado response = client.delete('/turmas/SCC5900/frequencias/100/presencas/', data=data, headers=headers) assert response.status_code == 400 assert response.json[ 'message'] == 'Não existe frequencia com esse ID no banco de dados.' # CLEAN UP clear_data(_db)