Skip to content

Commit

Permalink
Test that py:percent scripts end with exactly one blank line (#682)
Browse files Browse the repository at this point in the history
  • Loading branch information
mwouts committed Jan 15, 2021
1 parent f53facf commit d2898da
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 0 deletions.
3 changes: 3 additions & 0 deletions docs/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,9 @@ Jupytext ChangeLog
**Fixed**
- Indented magic commands are supported (#694)

**Added**
- Added a test that ensures that `py:percent` scripts end with exactly one blank line (#682)


1.9.1 (2021-01-06)
------------------
Expand Down
18 changes: 18 additions & 0 deletions tests/test_pep8.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
import pytest
from nbformat.v4.nbbase import new_code_cell, new_notebook

from jupytext.compare import compare
from jupytext import read, reads, writes
from jupytext.pep8 import (
Expand Down Expand Up @@ -199,3 +201,19 @@ def test_no_metadata_when_py_is_pep8(py_file):
assert cell.metadata == {"lines_to_next_cell": 0}, py_file
else:
assert not cell.metadata, (py_file, cell.source)


def test_notebook_ends_with_exactly_one_empty_line_682():
"""(Issue #682)
Steps to reproduce:
Have a notebook that ends in a python code cell (with no empty lines at the end of the cell).
run jupytext --to py:percent notebookWithCodeCell.ipynb.
See that the generated python code file has two empty lines at the end.
I would expect there to just be one new line."""
nb = new_notebook(
cells=[new_code_cell("1+1")], metadata={"jupytext": {"main_language": "python"}}
)
py = writes(nb, "py:percent")
assert py.endswith("1+1\n")

0 comments on commit d2898da

Please sign in to comment.