Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Refactor of JSON structure in response of get_by_code #4003

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

piemar1
Copy link
Contributor

@piemar1 piemar1 commented Aug 23, 2024

No description provided.

Copy link
Member

@WezSieTato WezSieTato left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Zostawiłem kilka komentarzy. Do tego trzeba poprawić formatowanie (statyczna analiza kodu się wywaliła na CI (https://github.com/KlubJagiellonski/pola-backend/actions/runs/10523617987/job/29196796842?pr=4003)
Jeśli chodzi o inne czeki to zrobiłem fixa w tym PRze #4005, po zmergowaniu trzeba bedzie domergować/zrebasować developa.

pola/rpc_api/openapi-v1.yaml Outdated Show resolved Hide resolved
@@ -200,7 +199,6 @@ def test_should_return_200_when_one_comand_in_brand_and_product(self):
self.maxDiff = None
self.assertEqual(
{
'all_company_brands': [{'logotype_url': None, 'name': p.brand.common_name}],
Copy link
Member

@WezSieTato WezSieTato Aug 26, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

NAzwa testu sugeruje, że te brand jest tu. Proponuje dodać marki do c1.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hmmm nie do końca wiem o co chodzi.
Dodałem brand w kodzie testu, sprawdźcie czo to o to chodziło czy coś innego.
Prośba o info to dorobię co trzeba.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Skoro mieliśmy all_company_brands to spodziewałbym się tutaj assertu, który będzie sprawdzał czy brands się pojawi. Ten test przechodzi po dodaniu brandu do modelu bez zmiany assertu?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

testy przechodzą, ale pamiętając zmianę struktury response, element brand (nawet jeśli jako pusta lista) musiałby istnieć wew elementu "comapnies", a tego też tutaj nie ma.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A jesteśmy wstanie go tak zmienić by ten brand był też w assercie? Ten test traci trochę sens w obecnej formie.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

powalczymy, muszę się wgryźć w kod, tutaj trzeba dodać nie tylko brands do responce , ale całą zawartość 'companies'

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@WezSieTato
Zrobiłem małą analizę w wgryzłem się bardzie w temat. I wygląda to na trochę grubszą sprawę, niestety.

  • test > test_should_return_200_when_one_comand_in_brand_and_product
  • dodanie 'brands', wewnątrz listy 'companies' jest obsługiwane w metodzie 'get_result_from_code' pod warunkiem że parametr multiple_company_supported=True, inaczej nie jest to wspierane. -> to jest też zmieniane w obecnym PR
  • domyślnie parametr multiple_company_supported=False
  • aby przy obecnych zmianach do response była dodawana lista 'companies' parametr '' musi być True w
    poniższej metodzie
    obraz
  • sęk w tym że mocno zmienia to odpowiedź z API - w efekcie zmianie ulegają dodatkowe 3 inne testy, poza testem 'test_should_return_200_when_one_comand_in_brand_and_product' nad którym pracowałem

obraz

Postaram się zająć tematem i zobaczyć czy nie ma jakiegoś obejścia, ale wstępnie wygląda to niestety na większą sprawę.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Co z tym testem? Jeśli jest to zbyt skomplikowane i trudne w utrzymaniu, to może go usuniemy/wyłaczymy?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sprawdziłem, porównałem 2 podobne testy jakie mamy dla v3

'test_should_return_200_when_one_comand_in_brand_and_product' oraz 'test_should_return_200_when_polish_and_known_product'

  • Różnica jest w danych wejściowych do testu - między dodaniem brandu do produktu i jego brakiem - i mimo tego wynik response jest podobny.
  • mają niemal identyczna asercję jeśli chodzi o response.content. Różnica jest tylko między kluczem 'product_id': p.id vs p.pk

Wygląda na to że odpowiedź responce jest w zasadzie identyczna a testy sprawdzają tą samą ścieżkę - ale wnioskuję tylko po teście. Nie mamy tutaj sprawdzenia % pokrycia kodu testami. Ale dane wejściowe są inne.

Osobiście jestem za pozostawieniem testu, można zmienić nazwę na odzwierciedlającą rzeczywistość,
np: test_should_return_200_with_product_no_brand_info.
Wychodzę z założenia że usunąć test można zawsze, jeśli zacznie rzeczywiście przeszkadzać albo nie będzie potrzebny.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Zmiana nazwy brzmi ok :)

pola/rpc_api/openapi-v1.yaml Show resolved Hide resolved
pola/rpc_api/openapi-v1.yaml Outdated Show resolved Hide resolved
Copy link

mergify bot commented Nov 15, 2024

Could you please fix the conflicts @piemar1? 🙏

@piemar1
Copy link
Contributor Author

piemar1 commented Nov 15, 2024

Rebased to master, but need to fix one error in test

@piemar1
Copy link
Contributor Author

piemar1 commented Nov 15, 2024

@WezSieTato
MR po wykonaniu rebase do mastera i naprawienia błędów w testach.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Reorganizacja struktury odpowiedzi JSON dla endpointu get_by_code
2 participants