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

INTERNAL ERROR: Black produced different code on the second pass of the formatter. #1855

Closed
semajson opened this issue Dec 1, 2020 · 1 comment
Labels
C: unstable formatting Formatting changed on the second pass R: duplicate This issue or pull request already exists T: bug Something isn't working

Comments

@semajson
Copy link

semajson commented Dec 1, 2020

Describe the bug When running black over the following code:

from test import ErrorDescription, event

def create_html_diags(html):
    if (True):
        if (True):
            if (True):
                try:
                    # Link to the Error
                    error_description_obj = ErrorDescription.objects.get(message = event["header"][:300])
                    html += '<a href="/errors/error%s/">CODE Error</a>' % error_description_obj.id
                    if error_description_obj.err_num is not None and error_description_obj.err_num != 0:
                        html += ' <small> - ERROR <a href="http:wwww.example.com/website?error=%s">%s</a></small>' % (
                            error_description_obj.err_num, error_description_obj.err_num)

                except:
                    html += "Internal  Error"

The error INTERNAL ERROR: Black produced different code on the second pass of the formatter. is reported

To Reproduce Run black over code snippet posted above

Expected behavior Black formats the file without error

Environment :

  • Version: 20.8b1
  • OS and Python version: Centos 7 / Python 2.7.5 (although code was from a python 2 script, I don't think it's a python 2 specific issue)

Does this bug also happen on master? Yes, it repos on https://black.now.sh/?version=master

Additional context Output of the of the diff file:

Mode(target_versions=set(), line_length=88, string_normalization=True, experimental_string_processing=False, is_pyi=False)
--- source
+++ first pass
@@ -1,17 +1,29 @@
 from test import ErrorDescription, event
 
+
 def create_html_diags(html):
-    if (True):
-        if (True):
-            if (True):
+    if True:
+        if True:
+            if True:
                 try:
                     # Link to the Error
-                    error_description_obj = ErrorDescription.objects.get(message = event["header"][:300])
-                    html += '<a href="/errors/error%s/">CODE Error</a>' % error_description_obj.id
-                    if error_description_obj.err_num is not None and error_description_obj.err_num != 0:
-                        html += ' <small> - ERROR <a href="http:wwww.example.com/website?error=%s">%s</a></small>' % (
-                            error_description_obj.err_num, error_description_obj.err_num)
-
+                    error_description_obj = ErrorDescription.objects.get(
+                        message=event["header"][:300]
+                    )
+                    html += (
+                        '<a href="/errors/error%s/">CODE Error</a>'
+                        % error_description_obj.id
+                    )
+                    if (
+                        error_description_obj.err_num is not None
+                        and error_description_obj.err_num != 0
+                    ):
+                        html += (
+                            ' <small> - ERROR <a href="http:wwww.example.com/website?error=%s">%s</a></small>'
+                            % (
+                                error_description_obj.err_num,
+                                error_description_obj.err_num,
+                            )
+                        )
                 except:
                     html += "Internal  Error"
-
--- first pass
+++ second pass
@@ -16,14 +16,11 @@
                     )
                     if (
                         error_description_obj.err_num is not None
                         and error_description_obj.err_num != 0
                     ):
-                        html += (
-                            ' <small> - ERROR <a href="http:wwww.example.com/website?error=%s">%s</a></small>'
-                            % (
-                                error_description_obj.err_num,
-                                error_description_obj.err_num,
-                            )
+                        html += ' <small> - ERROR <a href="http:wwww.example.com/website?error=%s">%s</a></small>' % (
+                            error_description_obj.err_num,
+                            error_description_obj.err_num,
                         )
                 except:
                     html += "Internal  Error"
@semajson semajson added the T: bug Something isn't working label Dec 1, 2020
@ichard26 ichard26 added the C: unstable formatting Formatting changed on the second pass label Dec 1, 2020
@ichard26 ichard26 added the R: duplicate This issue or pull request already exists label Apr 25, 2021
@ichard26
Copy link
Collaborator

Hello!

All reproduction cases in this issue format without error on master. The fixing commit was 8672af3 from PR GH-2126. I'll be marking this issue as a duplicate of GH-1629 since that's what GH-2126 aimed to fix and it's highly likely this issue falls under GH-1629.

Since we use the issue tracker as a reflection of what's on master, I'll be closing this issue. If you have any issues, especially with the new (but stable) output, please open a new issue. Oh and the fix should be available in a published release soon, see GH-2125 for more info.

Thank you for reporting!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
C: unstable formatting Formatting changed on the second pass R: duplicate This issue or pull request already exists T: bug Something isn't working
Projects
None yet
Development

No branches or pull requests

2 participants