diff --git a/ditto/core/templatetags/ditto_core.py b/ditto/core/templatetags/ditto_core.py index 7e9b26c8..cb18eae5 100644 --- a/ditto/core/templatetags/ditto_core.py +++ b/ditto/core/templatetags/ditto_core.py @@ -160,8 +160,7 @@ def current_url_name(context): """ url_name = False if context.request.resolver_match: - url_name = "{}:{}".format( - context.request.resolver_match.namespace, - context.request.resolver_match.url_name, - ) + namespace = context.request.resolver_match.namespace + name = context.request.resolver_match.url_name + url_name = f"{namespace}:{name}" return url_name diff --git a/ditto/core/views.py b/ditto/core/views.py index 3b5de043..7dd6a035 100644 --- a/ditto/core/views.py +++ b/ditto/core/views.py @@ -240,8 +240,9 @@ def set_app_and_variety(self, **kwargs): app_slug, variety_slug ) elif variety_slug: - msg = "'{}' is not a valid variety slug for the '{}' app slug.".format( - variety_slug, app_slug + msg = ( + f"'{variety_slug}' is not a valid variety slug for " + f"the '{app_slug}' app slug." ) raise Http404(msg) elif app_slug: diff --git a/ditto/flickr/admin.py b/ditto/flickr/admin.py index d3d7152c..12a3fc21 100644 --- a/ditto/flickr/admin.py +++ b/ditto/flickr/admin.py @@ -441,20 +441,18 @@ class PhotoAdmin(DittoItemModelAdmin): def show_thumb(self, instance): return mark_safe( - ''.format( - instance.thumbnail_url, - instance.thumbnail_width, - instance.thumbnail_height, - ) + f'' ) show_thumb.short_description = "Thumbnail" def show_image(self, instance): return mark_safe( - ''.format( - instance.small_url, instance.small_width, instance.small_height - ) + f'' ) show_image.short_description = "Small image" diff --git a/ditto/flickr/fetch/fetchers.py b/ditto/flickr/fetch/fetchers.py index 80788494..1c0e6e6f 100644 --- a/ditto/flickr/fetch/fetchers.py +++ b/ditto/flickr/fetch/fetchers.py @@ -551,8 +551,9 @@ def _fetch_photos_in_photoset(self, photoset_id): page=page_number, ) except FlickrError as err: - msg = "Error when fetching photos in photoset {} (page {}): {}".format( - photoset_id, page_number, err + msg = ( + f"Error when fetching photos in photoset {photoset_id} " + f"(page {page_number}): {err}" ) raise FetchError(msg) from err diff --git a/ditto/flickr/models.py b/ditto/flickr/models.py index be951406..e403eb3b 100644 --- a/ditto/flickr/models.py +++ b/ditto/flickr/models.py @@ -495,6 +495,9 @@ def upload_path(self, filename): class Meta: ordering = ("-post_time",) + def __str__(self): + return super().__str_(self) + def save(self, *args, **kwargs): if self.taken_time: self.taken_year = self.taken_time.year @@ -681,12 +684,9 @@ def _remote_image_url(self, size): # Medium size doesn't have a letter suffix. if self.PHOTO_SIZES[size]["suffix"]: size_ext = "_{}".format(self.PHOTO_SIZES[size]["suffix"]) - return "https://farm{}.static.flickr.com/{}/{}_{}{}.jpg".format( - self.farm, - self.server, - self.flickr_id, - self.secret, - size_ext, + return ( + f"https://farm{self.farm}.static.flickr.com/{self.server}/" + f"{self.flickr_id}_{self.secret}{size_ext}.jpg" ) def _video_url(self, size): @@ -912,10 +912,9 @@ def avatar_url(self): def original_icon_url(self): """URL of the avatar/profile pic at Flickr.""" if self.iconserver: - return "https://farm{}.staticflickr.com/{}/buddyicons/{}.jpg".format( - self.iconfarm, - self.iconserver, - self.nsid, + return ( + f"https://farm{self.iconfarm}.staticflickr.com/{self.iconserver}" + f"/buddyicons/{self.nsid}.jpg" ) else: return "https://www.flickr.com/images/buddyicon.gif" diff --git a/ditto/flickr/templatetags/ditto_flickr.py b/ditto/flickr/templatetags/ditto_flickr.py index 4fe85543..4007717f 100644 --- a/ditto/flickr/templatetags/ditto_flickr.py +++ b/ditto/flickr/templatetags/ditto_flickr.py @@ -85,9 +85,8 @@ def photo_license(n): if n in licenses: if n in Photo.LICENSE_URLS and Photo.LICENSE_URLS[n] != "": return format_html( - '{}'.format( - Photo.LICENSE_URLS[n], licenses[n] - ) + f'' + f"{licenses[n]}" ) else: return licenses[n] diff --git a/ditto/lastfm/models.py b/ditto/lastfm/models.py index cb8144ef..c47e4d3d 100644 --- a/ditto/lastfm/models.py +++ b/ditto/lastfm/models.py @@ -111,10 +111,8 @@ def get_absolute_url(self): @property def permalink(self): "The Album's URL at Last.fm." - return "{}/music/{}/{}".format( - LASTFM_URL_ROOT, - self.artist.original_slug, - self.original_slug, + return ( + f"{LASTFM_URL_ROOT}/music/{self.artist.original_slug}/{self.original_slug}" ) @property @@ -339,10 +337,9 @@ def get_absolute_url(self): @property def permalink(self): "The Track's URL at Last.fm." - return "{}/music/{}/_/{}".format( - LASTFM_URL_ROOT, - self.artist.original_slug, - self.original_slug, + return ( + f"{LASTFM_URL_ROOT}/music/{self.artist.original_slug}/_/" + f"{self.original_slug}" ) @property diff --git a/ditto/twitter/admin.py b/ditto/twitter/admin.py index 089cb298..2ea2ef80 100644 --- a/ditto/twitter/admin.py +++ b/ditto/twitter/admin.py @@ -155,29 +155,24 @@ class MediaAdmin(admin.ModelAdmin): def show_thumb(self, instance): return mark_safe( - ''.format( - instance.thumbnail_url, - instance.thumbnail_w, - instance.thumbnail_h, - ) + f'' ) show_thumb.short_description = "" def show_image(self, instance): if instance.media_type == "photo": - html = ''.format( - instance.small_url, - instance.small_w, - instance.small_h, + html = ( + f'' ) else: - html = ''.format( # noqa: E501 - instance.small_w, - instance.small_h, - instance.small_url, - instance.video_url, - instance.video_mime_type, + html = ( + f'" ) return mark_safe(html) diff --git a/ditto/twitter/models.py b/ditto/twitter/models.py index 0153c9c2..f173c71a 100644 --- a/ditto/twitter/models.py +++ b/ditto/twitter/models.py @@ -607,9 +607,9 @@ def is_reply(self): def in_reply_to_url(self): "If it's a reply, the link to the tweet replied to." if self.is_reply: - return "https://twitter.com/{}/status/{}".format( - self.in_reply_to_screen_name, - self.in_reply_to_status_id, + return ( + f"https://twitter.com/{self.in_reply_to_screen_name}/" + f"status/{self.in_reply_to_status_id}" ) else: return "" diff --git a/tests/pinboard/test_fetch.py b/tests/pinboard/test_fetch.py index d8d4c55a..8d2a4915 100644 --- a/tests/pinboard/test_fetch.py +++ b/tests/pinboard/test_fetch.py @@ -74,10 +74,9 @@ def make_success_body( if method == "all": return posts_json else: - return '{{"date":"{}T09:48:31Z","user":"{}","posts":{}}}\t\n'.format( - post_date, - username, - posts_json, + return ( + f'{{"date":"{post_date}T09:48:31Z","user":"{username}",' + f'"posts":{posts_json}}}\t\n' ) # Check that all interface methods return expected results on success. diff --git a/tests/twitter/test_fetch_fetchers.py b/tests/twitter/test_fetch_fetchers.py index dd53f7f7..dff5897b 100644 --- a/tests/twitter/test_fetch_fetchers.py +++ b/tests/twitter/test_fetch_fetchers.py @@ -976,10 +976,9 @@ def test_saves_downloaded_image_file(self, download): FetchFiles()._fetch_and_save_file(self.image, "image") self.assertEqual( self.image.image_file.name, - "twitter/media/{}/{}/{}".format( - temp_filepath[-4:-2], - temp_filepath[-2:], - os.path.basename(temp_filepath), + ( + f"twitter/media/{temp_filepath[-4:-2]}/{temp_filepath[-2:]}/" + f"{os.path.basename(temp_filepath)}", ), ) @@ -994,9 +993,8 @@ def test_saves_downloaded_mp4_file(self, download): FetchFiles()._fetch_and_save_file(self.animated_gif, "mp4") self.assertEqual( self.animated_gif.mp4_file.name, - "twitter/media/{}/{}/{}".format( - temp_filepath[-4:-2], - temp_filepath[-2:], - os.path.basename(temp_filepath), + ( + f"twitter/media/{temp_filepath[-4:-2]}/{temp_filepath[-2:]}/" + f"{os.path.basename(temp_filepath)}", ), )