Skip to content

Commit

Permalink
Fallback до None или [] при данных неправильного типа; исправлен type…
Browse files Browse the repository at this point in the history
… hint de_list и тесты на empty list (#612)
  • Loading branch information
MarshalX authored Aug 15, 2023
1 parent a171583 commit 2e7bd8f
Show file tree
Hide file tree
Showing 164 changed files with 269 additions and 252 deletions.
2 changes: 1 addition & 1 deletion tests/test_album.py
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ def test_de_json_none(self, client):
assert Album.de_json({}, client) is None

def test_de_list_none(self, client):
assert Album.de_list({}, client) == []
assert Album.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {'id': self.id}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_album_event.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ def test_de_json_none(self, client):
assert AlbumEvent.de_json({}, client) is None

def test_de_list_none(self, client):
assert AlbumEvent.de_list({}, client) == []
assert AlbumEvent.de_list([], client) == []

def test_de_json_required(self, client, album, track):
json_dict = {'album': album.to_dict(), 'tracks': [track.to_dict()]}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_artist.py
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ def test_de_json_none(self, client):
assert Artist.de_json({}, client) is None

def test_de_list_none(self, client):
assert Artist.de_list({}, client) == []
assert Artist.de_list([], client) == []

def test_de_json_required(self, client, cover):
json_dict = {'id': self.id}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_artist_event.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ def test_de_json_none(self, client):
assert ArtistEvent.de_json({}, client) is None

def test_de_list_none(self, client):
assert ArtistEvent.de_list({}, client) == []
assert ArtistEvent.de_list([], client) == []

def test_de_json_required(self, client, artist, track):
json_dict = {
Expand Down
2 changes: 1 addition & 1 deletion tests/test_auto_renewable.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ def test_de_json_none(self, client):
assert AutoRenewable.de_json({}, client) is None

def test_de_list_none(self, client):
assert AutoRenewable.de_list({}, client) == []
assert AutoRenewable.de_list([], client) == []

def test_de_json_required(self, client, product):
json_dict = {
Expand Down
2 changes: 1 addition & 1 deletion tests/test_block.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ def test_de_json_none(self, client):
assert Block.de_json({}, client) is None

def test_de_list_none(self, client):
assert Block.de_list({}, client) == []
assert Block.de_list([], client) == []

def test_de_json_required(self, client, block_entity):
json_dict = {
Expand Down
2 changes: 1 addition & 1 deletion tests/test_block_entity.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ def test_expected_values(self, block_entity_with_data_and_type):
assert block_entity.data == data

def test_de_list_none(self, client):
assert BlockEntity.de_list({}, client) == []
assert BlockEntity.de_list([], client) == []

def test_de_json_none(self, client):
assert BlockEntity.de_json({}, client) is None
Expand Down
2 changes: 1 addition & 1 deletion tests/test_chart.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ def test_de_json_none(self, client):
assert Chart.de_json({}, client) is None

def test_de_list_none(self, client):
assert Chart.de_list({}, client) == []
assert Chart.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {
Expand Down
2 changes: 1 addition & 1 deletion tests/test_chart_item.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ def test_de_json_none(self, client):
assert ChartItem.de_json({}, client) is None

def test_de_list_none(self, client):
assert ChartItem.de_list({}, client) == []
assert ChartItem.de_list([], client) == []

def test_de_json_required(self, client, track, chart):
json_dict = {'track': track.to_dict(), 'chart': chart.to_dict()}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_cover.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ def test_de_json_none(self, client):
assert Cover.de_json({}, client) is None

def test_de_list_none(self, client):
assert Cover.de_list({}, client) == []
assert Cover.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_day.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ def test_de_json_none(self, client):
assert Day.de_json({}, client) is None

def test_de_list_none(self, client):
assert Day.de_list({}, client) == []
assert Day.de_list([], client) == []

def test_de_json_required(self, client, event, track_with_ads, track):
json_dict = {
Expand Down
2 changes: 1 addition & 1 deletion tests/test_deactivation.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ def test_de_json_none(self, client):
assert Deactivation.de_json({}, client) is None

def test_de_list_none(self, client):
assert Deactivation.de_list({}, client) == []
assert Deactivation.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {'method': self.method}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_download_info.py
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ def test_de_json_none(self, client):
assert DownloadInfo.de_json({}, client) is None

def test_de_list_none(self, client):
assert DownloadInfo.de_list({}, client) == []
assert DownloadInfo.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {
Expand Down
2 changes: 1 addition & 1 deletion tests/test_event.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ def test_de_json_none(self, client):
assert Event.de_json({}, client) is None

def test_de_list_none(self, client):
assert Event.de_list({}, client) == []
assert Event.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {'id': self.id, 'type': self.type}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_generated_playlist.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ def test_de_json_none(self, client):
assert GeneratedPlaylist.de_json({}, client) is None

def test_de_list_none(self, client):
assert GeneratedPlaylist.de_list({}, client) == []
assert GeneratedPlaylist.de_list([], client) == []

def test_de_json_required(self, client, playlist):
json_dict = {'type': self.type, 'ready': self.ready, 'notify': self.notify, 'data': playlist.to_dict()}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_genre.py
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@ def test_de_json_none(self, client):
assert Genre.de_json({}, client) is None

def test_de_list_none(self, client):
assert Genre.de_list({}, client) == []
assert Genre.de_list([], client) == []

def test_de_json_required(self, client, title, images):
json_dict = {
Expand Down
2 changes: 1 addition & 1 deletion tests/test_label.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ def test_expected_values(self, label):
assert label.name == self.name

def test_de_list_none(self, client):
assert Label.de_list({}, client) == []
assert Label.de_list([], client) == []

def test_de_json_none(self, client):
assert Label.de_json({}, client) is None
Expand Down
2 changes: 1 addition & 1 deletion tests/test_licence_text_part.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ def test_de_json_none(self, client):
assert LicenceTextPart.de_json({}, client) is None

def test_de_list_none(self, client):
assert LicenceTextPart.de_list({}, client) == []
assert LicenceTextPart.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {'text': self.text}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_like.py
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ def test_de_json_none(self, client):
assert Like.de_json({}, client) is None

def test_de_list_none(self, client):
assert Like.de_list({}, client) == []
assert Like.de_list([], client) == []

@pytest.mark.parametrize('param', [2, 3, 4])
def test_de_json_all(self, results, types, client, param):
Expand Down
2 changes: 1 addition & 1 deletion tests/test_link.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ def test_de_json_none(self, client):
assert Link.de_json({}, client) is None

def test_de_list_none(self, client):
assert Link.de_list({}, client) == []
assert Link.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {'title': self.title, 'href': self.href, 'type': self.type}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_mix_link.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ def test_de_json_none(self, client):
assert MixLink.de_json({}, client) is None

def test_de_list_none(self, client):
assert MixLink.de_list({}, client) == []
assert MixLink.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {
Expand Down
2 changes: 1 addition & 1 deletion tests/test_operator.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ def test_de_json_none(self, client):
assert Operator.de_json({}, client) is None

def test_de_list_none(self, client):
assert Operator.de_list({}, client) == []
assert Operator.de_list([], client) == []

def test_de_json_required(self, client, deactivation):
json_dict = {
Expand Down
2 changes: 1 addition & 1 deletion tests/test_passport_phone.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ def test_de_json_none(self, client):
assert PassportPhone.de_json({}, client) is None

def test_de_list_none(self, client):
assert PassportPhone.de_list({}, client) == []
assert PassportPhone.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {'phone': self.phone}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_playlist.py
Original file line number Diff line number Diff line change
Expand Up @@ -124,7 +124,7 @@ def test_de_json_none(self, client):
assert Playlist.de_json({}, client) is None

def test_de_list_none(self, client):
assert Playlist.de_list({}, client) == []
assert Playlist.de_list([], client) == []

def test_de_json_required(self, client, user, cover, made_for, play_counter, playlist_absence):
json_dict = {
Expand Down
2 changes: 1 addition & 1 deletion tests/test_playlist_id.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ def test_de_json_none(self, client):
assert PlaylistId.de_json({}, client) is None

def test_de_list_none(self, client):
assert PlaylistId.de_list({}, client) == []
assert PlaylistId.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {'uid': self.uid, 'kind': self.kind}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_poetry_lover_match.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ def test_de_json_none(self, client):
assert PoetryLoverMatch.de_json({}, client) is None

def test_de_list_none(self, client):
assert PoetryLoverMatch.de_list({}, client) == []
assert PoetryLoverMatch.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {'begin': self.begin, 'end': self.end, 'line': self.line}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_product.py
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,7 @@ def test_de_json_none(self, client):
assert Product.de_json({}, client) is None

def test_de_list_none(self, client):
assert Product.de_list({}, client) == []
assert Product.de_list([], client) == []

def test_de_json_required(self, client, price):
json_dict = {
Expand Down
2 changes: 1 addition & 1 deletion tests/test_promotion.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ def test_expected_values(self, promotion):
assert promotion.image == self.image

def test_de_list_none(self, client):
assert Promotion.de_list({}, client) == []
assert Promotion.de_list([], client) == []

def test_de_json_none(self, client):
assert Promotion.de_json({}, client) is None
Expand Down
2 changes: 1 addition & 1 deletion tests/test_queue_item.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ def test_de_json_none(self, client):
assert QueueItem.de_json({}, client) is None

def test_de_list_none(self, client):
assert QueueItem.de_list({}, client) == []
assert QueueItem.de_list([], client) == []

def test_de_json_required(self, client, context):
json_dict = {'id': self.id_, 'context': context.to_dict(), 'modified': self.modified}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_sequence.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ def test_de_json_none(self, client):
assert Sequence.de_json({}, client) is None

def test_de_list_none(self, client):
assert Sequence.de_list({}, client) == []
assert Sequence.de_list([], client) == []

def test_de_json_required(self, client, track):
json_dict = {'type': self.type, 'track': track.to_dict(), 'liked': self.liked}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_shot.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ def test_de_json_none(self, client):
assert Shot.de_json({}, client) is None

def test_de_list_none(self, client):
assert Shot.de_list({}, client) == []
assert Shot.de_list([], client) == []

def test_de_json_required(self, client, shot_data):
json_dict = {
Expand Down
2 changes: 1 addition & 1 deletion tests/test_station_result.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ def test_de_json_none(self, client):
assert StationResult.de_json({}, client) is None

def test_de_list_none(self, client):
assert StationResult.de_list({}, client) == []
assert StationResult.de_list([], client) == []

def test_de_json_required(self, client, station, rotor_settings, ad_params):
json_dict = {
Expand Down
2 changes: 1 addition & 1 deletion tests/test_track.py
Original file line number Diff line number Diff line change
Expand Up @@ -102,7 +102,7 @@ def test_de_json_none(self, client):
assert Track.de_json({}, client) is None

def test_de_list_none(self, client):
assert Track.de_list({}, client) == []
assert Track.de_list([], client) == []

def test_de_json_required(self, client, artist, album):
json_dict = {'id': self.id}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_track_id.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ def test_de_json_none(self, client):
assert TrackId.de_json({}, client) is None

def test_de_list_none(self, client):
assert TrackId.de_list({}, client) == []
assert TrackId.de_list([], client) == []

def test_de_json_all(self, client):
json_dict = {'id': self.id, 'track_id': self.track_id, 'album_id': self.album_id, 'from_': self.from_}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_track_short.py
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ def test_de_json_none(self, client):
assert TrackShort.de_json({}, client) is None

def test_de_list_none(self, client):
assert TrackShort.de_list({}, client) == []
assert TrackShort.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {'id': self.id, 'timestamp': self.timestamp}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_track_short_old.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ def test_de_json_none(self, client):
assert TrackShortOld.de_json({}, client) is None

def test_de_list_none(self, client):
assert TrackShortOld.de_list({}, client) == []
assert TrackShortOld.de_list([], client) == []

def test_de_json_required(self, client, track_id):
json_dict = {'track_id': track_id.to_dict(), 'timestamp': self.timestamp}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_track_with_ads.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ def test_de_json_none(self, client):
assert TrackWithAds.de_json({}, client) is None

def test_de_list_none(self, client):
assert TrackWithAds.de_list({}, client) == []
assert TrackWithAds.de_list([], client) == []

def test_de_json_required(self, client, track):
json_dict = {'type': self.type, 'track': track.to_dict()}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_user.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ def test_de_json_none(self, client):
assert User.de_json({}, client) is None

def test_de_list_none(self, client):
assert User.de_list({}, client) == []
assert User.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {'uid': self.uid, 'login': self.login}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_value.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ def test_de_json_none(self, client):
assert Value.de_json({}, client) is None

def test_de_list_none(self, client):
assert Value.de_list({}, client) == []
assert Value.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {'value': self.value, 'name': self.name}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_video.py
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ def test_de_json_none(self, client):
assert Video.de_json({}, client) is None

def test_de_list_none(self, client):
assert Video.de_list({}, client) == []
assert Video.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {'title': self.title}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_video_supplement.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ def test_de_json_none(self, client):
assert VideoSupplement.de_json({}, client) is None

def test_de_list_none(self, client):
assert VideoSupplement.de_list({}, client) == []
assert VideoSupplement.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {'cover': self.cover, 'provider': self.provider}
Expand Down
2 changes: 1 addition & 1 deletion tests/test_vinyl.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ def test_de_json_none(self, client):
assert Vinyl.de_json({}, client) is None

def test_de_list_none(self, client):
assert Vinyl.de_list({}, client) == []
assert Vinyl.de_list([], client) == []

def test_de_json_required(self, client):
json_dict = {
Expand Down
2 changes: 1 addition & 1 deletion yandex_music/account/account.py
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,7 @@ def de_json(cls, data: dict, client: 'Client') -> Optional['Account']:
Returns:
:obj:`yandex_music.Account`: Основная информация об аккаунте пользователя.
"""
if not data:
if not cls.is_valid_model_data(data):
return None

data = super(Account, cls).de_json(data, client)
Expand Down
2 changes: 1 addition & 1 deletion yandex_music/account/alert.py
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ def de_json(cls, data: dict, client: 'Client') -> Optional['Alert']:
Returns:
:obj:`yandex_music.Alert`: Сообщение о статусе подписки.
"""
if not data:
if not cls.is_valid_model_data(data):
return None

from yandex_music import AlertButton
Expand Down
Loading

0 comments on commit 2e7bd8f

Please sign in to comment.