-
Notifications
You must be signed in to change notification settings - Fork 118
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'keras-team:main' into Increase-test-coverage-keras_core…
…-saving
- Loading branch information
Showing
7 changed files
with
395 additions
and
38 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,142 @@ | ||
import os | ||
import sys | ||
from io import StringIO | ||
|
||
from keras_core.testing import test_case | ||
from keras_core.utils.code_stats import count_loc | ||
|
||
|
||
class TestCountLoc(test_case.TestCase): | ||
def setUp(self): | ||
self.test_dir = "test_directory" | ||
os.makedirs(self.test_dir, exist_ok=True) | ||
|
||
def tearDown(self): | ||
for root, dirs, files in os.walk(self.test_dir, topdown=False): | ||
for name in files: | ||
os.remove(os.path.join(root, name)) | ||
for name in dirs: | ||
os.rmdir(os.path.join(root, name)) | ||
|
||
def create_file(self, filename, content): | ||
with open( | ||
os.path.join(self.test_dir, filename), "w", encoding="utf-8" | ||
) as f: | ||
f.write(content) | ||
|
||
def test_count_loc_valid_python(self): | ||
self.create_file( | ||
"sample.py", "# This is a test file\n\nprint('Hello')\n" | ||
) | ||
loc = count_loc(self.test_dir) | ||
self.assertEqual(loc, 1) | ||
|
||
def test_exclude_test_files(self): | ||
self.create_file("sample_test.py", "print('Hello')\n") | ||
loc = count_loc(self.test_dir, exclude=("_test",)) | ||
self.assertEqual(loc, 0) | ||
|
||
def test_other_extensions(self): | ||
self.create_file("sample.txt", "Hello\n") | ||
loc = count_loc(self.test_dir, extensions=(".py",)) | ||
self.assertEqual(loc, 0) | ||
|
||
def test_comment_lines(self): | ||
self.create_file( | ||
"sample.py", "# Comment\nprint('Hello')\n# Another comment\n" | ||
) | ||
loc = count_loc(self.test_dir) | ||
self.assertEqual(loc, 1) | ||
|
||
def test_empty_file(self): | ||
self.create_file("empty.py", "") | ||
loc = count_loc(self.test_dir) | ||
self.assertEqual(loc, 0) | ||
|
||
def test_whitespace_only(self): | ||
self.create_file("whitespace.py", " \n\t\n") | ||
loc = count_loc(self.test_dir) | ||
self.assertEqual(loc, 0) | ||
|
||
def test_inline_comments_after_code(self): | ||
content = 'print("Hello") # This is an inline comment' | ||
self.create_file("inline_comment_sample.py", content) | ||
loc = count_loc(self.test_dir) | ||
self.assertEqual(loc, 1) # The comment shouldn't affect the count | ||
|
||
def test_directory_structure(self): | ||
content1 = 'print("Hello from file1")' | ||
content2 = 'print("Hello from file2")' | ||
os.mkdir(os.path.join(self.test_dir, "subdir")) | ||
self.create_file("sample1.py", content1) | ||
self.create_file(os.path.join("subdir", "sample2.py"), content2) | ||
loc = count_loc(self.test_dir) | ||
self.assertEqual(loc, 2) # Both files should be counted | ||
|
||
def test_normal_directory_name(self): | ||
content = 'print("Hello from a regular directory")' | ||
os.makedirs(os.path.join(self.test_dir, "some_test_dir")) | ||
self.create_file(os.path.join("some_test_dir", "sample.py"), content) | ||
loc = count_loc(self.test_dir) | ||
self.assertEqual(loc, 1) # Should count normally | ||
|
||
def test_exclude_directory_name(self): | ||
content = 'print("Hello from an excluded directory")' | ||
os.makedirs(os.path.join(self.test_dir, "dir_test")) | ||
self.create_file(os.path.join("dir_test", "sample.py"), content) | ||
loc = count_loc(self.test_dir) | ||
self.assertEqual(loc, 0) | ||
# Shouldn't count the file in dir_test due to the exclusion pattern | ||
|
||
def test_verbose_output(self): | ||
content = 'print("Hello")' | ||
self.create_file("sample.py", content) | ||
original_stdout = sys.stdout | ||
sys.stdout = StringIO() | ||
count_loc(self.test_dir, verbose=1) | ||
output = sys.stdout.getvalue() | ||
sys.stdout = original_stdout | ||
self.assertIn("Count LoCs in", output) | ||
|
||
def test_multiline_string_same_line(self): | ||
content = '''"""This is a multiline string ending on the same line""" | ||
print("Outside string")''' | ||
self.create_file("same_line_multiline.py", content) | ||
loc = count_loc(self.test_dir) | ||
self.assertEqual(loc, 1) # Only the print statement should count | ||
|
||
def test_multiline_string_ends_on_same_line(self): | ||
content = '"""a multiline string end on same line"""\nprint("Outstr")' | ||
self.create_file("same_line_multiline.py", content) | ||
loc = count_loc(self.test_dir) | ||
self.assertEqual(loc, 1) # Only the print statement should count | ||
|
||
def test_multiline_string_ends_in_middle_of_line(self): | ||
content = '''print("Start") | ||
"""This is a multiline string ending in the middle of a line""" | ||
"""This is another multiline string.""" | ||
print("End")''' | ||
self.create_file("multiline_in_middle.py", content) | ||
loc = count_loc(self.test_dir) | ||
self.assertEqual(loc, 2) # Both print statements should count | ||
|
||
def test_line_starting_with_triple_quotes_not_ending(self): | ||
content = '"""\nThis is a multiline string\n' | ||
self.create_file("test_file_2.py", content) | ||
path = os.path.join(self.test_dir, "test_file_2.py") | ||
self.assertEqual(count_loc(path), 0) | ||
# Because it's part of a multiline string | ||
|
||
def test_line_starting_and_ending_with_triple_quotes(self): | ||
content = '"""This is a one-liner docstring."""\n' | ||
self.create_file("test_file_3.py", content) | ||
path = os.path.join(self.test_dir, "test_file_3.py") | ||
self.assertEqual(count_loc(path), 0) | ||
# This is still considered a comment/docstring | ||
|
||
def test_string_open_true_line_starting_with_triple_quotes(self): | ||
content = '"""\nEnd of the multiline string."""\n' | ||
self.create_file("test_file_4.py", content) | ||
path = os.path.join(self.test_dir, "test_file_4.py") | ||
self.assertEqual(count_loc(path), 0) | ||
# Entire content is a multiline string/comment |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.