mirror of https://github.com/gmbrax/Pilgrim.git
				
				
				
			Merge pull request #84 from gmbrax/test/entryservice-unit-test
Add the tests for the new methods of deleting
This commit is contained in:
		
						commit
						ed55d33bc6
					
				|  | @ -1,7 +1,10 @@ | ||||||
|  | from datetime import datetime | ||||||
|  | 
 | ||||||
| import pytest | import pytest | ||||||
| from sqlalchemy import create_engine | from sqlalchemy import create_engine | ||||||
| from sqlalchemy.orm import sessionmaker | from sqlalchemy.orm import sessionmaker | ||||||
| 
 | 
 | ||||||
|  | from pilgrim.models.entry import Entry | ||||||
| from pilgrim.database import Base | from pilgrim.database import Base | ||||||
| from pilgrim.models.travel_diary import TravelDiary | from pilgrim.models.travel_diary import TravelDiary | ||||||
| from pilgrim.models.photo import Photo | from pilgrim.models.photo import Photo | ||||||
|  | @ -62,3 +65,23 @@ def session_with_photos(session_with_one_diary): | ||||||
|     session.commit() |     session.commit() | ||||||
| 
 | 
 | ||||||
|     return session, [photo1, photo2] |     return session, [photo1, photo2] | ||||||
|  | 
 | ||||||
|  | @pytest.fixture | ||||||
|  | def entry_with_photo_references(session_with_one_diary): | ||||||
|  |     session, diary = session_with_one_diary | ||||||
|  |     photo1 = Photo(filepath="p1.jpg", name="P1", photo_hash="aaaaaaaa", fk_travel_diary_id=diary.id) | ||||||
|  |     photo2 = Photo(filepath="p2.jpg", name="P2", photo_hash="bbbbbbbb", fk_travel_diary_id=diary.id) | ||||||
|  |     session.add_all([photo1, photo2]) | ||||||
|  |     session.flush() | ||||||
|  |     entry = Entry( | ||||||
|  |         title="Entrada com Fotos", | ||||||
|  |         text="Texto com a foto A [[photo::aaaaaaaa]] e também a foto B [[photo::bbbbbbbb]].", | ||||||
|  |         date=datetime.now(), | ||||||
|  |         travel_diary_id=diary.id, | ||||||
|  |         photos=[photo1, photo2] | ||||||
|  |     ) | ||||||
|  |     session.add(entry) | ||||||
|  |     session.commit() | ||||||
|  |     session.refresh(entry) | ||||||
|  | 
 | ||||||
|  |     return session, entry | ||||||
|  |  | ||||||
|  | @ -261,3 +261,46 @@ def test_delete_returns_none_if_entry_does_not_exist(db_session): | ||||||
|     non_existent_entry.id = 999 |     non_existent_entry.id = 999 | ||||||
|     result = service.delete(non_existent_entry) |     result = service.delete(non_existent_entry) | ||||||
|     assert result is None |     assert result is None | ||||||
|  | 
 | ||||||
|  | def test_delete_references_for_specific_photo(entry_with_photo_references): | ||||||
|  |     session, entry = entry_with_photo_references | ||||||
|  |     service = EntryService(session) | ||||||
|  |     updated_entry = service.delete_references_for_specific_photo(entry, "aaaaaaaa") | ||||||
|  |     assert "[[photo::aaaaaaaa]]" not in updated_entry.text | ||||||
|  |     assert "[[photo::bbbbbbbb]]" in updated_entry.text | ||||||
|  | 
 | ||||||
|  | def test_delete_specific_photo_reference_does_nothing_if_no_match(entry_with_photo_references): | ||||||
|  |     session, entry = entry_with_photo_references | ||||||
|  |     service = EntryService(session) | ||||||
|  | 
 | ||||||
|  |     original_text = entry.text | ||||||
|  |     updated_entry = service.delete_references_for_specific_photo(entry, "cccccccc") | ||||||
|  |     assert updated_entry.text == original_text | ||||||
|  | 
 | ||||||
|  | def test_delete_all_photo_references_removes_all_refs(entry_with_photo_references): | ||||||
|  |     session, entry = entry_with_photo_references | ||||||
|  |     service = EntryService(session) | ||||||
|  |     updated_entry = service.delete_all_photo_references(entry) | ||||||
|  |     assert "[[photo::aaaaaaaa]]" not in updated_entry.text | ||||||
|  |     assert "[[photo::bbbbbbbb]]" not in updated_entry.text | ||||||
|  | 
 | ||||||
|  | def test_delete_all_photo_references_uses_truncated_hash(session_with_one_diary): | ||||||
|  |     session, diary = session_with_one_diary | ||||||
|  |     service = EntryService(session) | ||||||
|  |     long_hash_photo = Photo( | ||||||
|  |         filepath="long.jpg", name="Long", | ||||||
|  |         photo_hash="1234567890abcdef",  # Hash com 16 caracteres | ||||||
|  |         fk_travel_diary_id=diary.id | ||||||
|  |     ) | ||||||
|  |     entry = Entry( | ||||||
|  |         title="Teste de Hash Curto", | ||||||
|  |         text="Referência com hash truncado [[photo::12345678]].",  # Texto usa só os 8 primeiros | ||||||
|  |         date=datetime.now(), | ||||||
|  |         travel_diary_id=diary.id | ||||||
|  |     ) | ||||||
|  |     entry.photos.append(long_hash_photo) | ||||||
|  |     session.add_all([long_hash_photo, entry]) | ||||||
|  |     session.commit() | ||||||
|  |     updated_entry = service.delete_all_photo_references(entry) | ||||||
|  |     expected_text = "Referência com hash truncado                   ." | ||||||
|  |     assert "[[photo::12345678]]" not in updated_entry.text | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue