Skip to content

Commit

Permalink
fix: update pandas.read_json syntax
Browse files Browse the repository at this point in the history
Pandas has deprecated read_json(string), so we now use
read_json(StringIO) instead. README has been updated with
new syntax.
  • Loading branch information
alubbock committed Aug 17, 2024
1 parent 5f98938 commit 1a65b77
Show file tree
Hide file tree
Showing 6 changed files with 15 additions and 12 deletions.
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,7 @@ into a `io.StringIO()` buffer, which can be read as follows

```python
import pandas as pd
results = pd.read_json(basic_bench.outfile.getvalue(), lines=True)
results = pd.read_json(basic_bench.outfile, lines=True)
```

The above example captures the fields `start_time`, `finish_time`,
Expand Down Expand Up @@ -219,7 +219,7 @@ def my_function():
my_function()

# Read the results into a Pandas DataFrame
results = pandas.read_json(lpbench.outfile.getvalue(), lines=True)
results = pandas.read_json(lpbench.outfile, lines=True)

# Get the line profiler report as an object
lp = MBLineProfiler.decode_line_profile(results['line_profiler'][0])
Expand Down
2 changes: 2 additions & 0 deletions microbench/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -175,6 +175,8 @@ def output_result(self, bm_data):
else:
# Assume file-like object
self.outfile.write(bm_str)
# Seek to beginning to allow read
self.outfile.seek(0)

def __call__(self, func):
def inner(*args, **kwargs):
Expand Down
14 changes: 7 additions & 7 deletions microbench/tests/test_base.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ def my_function():
for _ in range(3):
assert my_function() == 499999500000

results = pandas.read_json(benchmark.outfile.getvalue(), lines=True)
results = pandas.read_json(benchmark.outfile, lines=True)
assert (results['function_name'] == 'my_function').all()
assert results['package_versions'][0]['pandas'] == pandas.__version__
runtimes = results['finish_time'] - results['start_time']
Expand All @@ -50,7 +50,7 @@ def my_function():
# call the function
my_function()

results = pandas.read_json(benchmark.outfile.getvalue(), lines=True)
results = pandas.read_json(benchmark.outfile, lines=True)
assert (results['function_name'] == 'my_function').all()
runtimes = results['finish_time'] - results['start_time']
assert (runtimes >= datetime.timedelta(0)).all()
Expand All @@ -68,7 +68,7 @@ def noop():

noop()

results = pandas.read_json(globals_bench.outfile.getvalue(), lines=True)
results = pandas.read_json(globals_bench.outfile, lines=True)

# We should've captured microbench and pandas versions from top level
# imports in this file
Expand All @@ -89,7 +89,7 @@ def noop():

noop()

results = pandas.read_json(pkg_bench.outfile.getvalue(), lines=True)
results = pandas.read_json(pkg_bench.outfile, lines=True)
assert pandas.__version__ == results['package_versions'][0]['pandas']


Expand All @@ -111,7 +111,7 @@ def noop():
assert not telem_bench._telemetry_thread.is_alive()

# Check some telemetry was captured
results = pandas.read_json(telem_bench.outfile.getvalue(), lines=True)
results = pandas.read_json(telem_bench.outfile, lines=True)
assert len(results['telemetry']) > 0


Expand All @@ -135,7 +135,7 @@ def dummy(arg1, arg2):
assert all(issubclass(w_.category, JSONEncodeWarning) for w_ in w)


results = pandas.read_json(bench.outfile.getvalue(), lines=True)
results = pandas.read_json(bench.outfile, lines=True)
assert results['args'][0] == [_UNENCODABLE_PLACEHOLDER_VALUE]
assert results['kwargs'][0] == {'arg2': _UNENCODABLE_PLACEHOLDER_VALUE}
assert results['return_value'][0] == _UNENCODABLE_PLACEHOLDER_VALUE
Expand Down Expand Up @@ -173,5 +173,5 @@ def dummy():

dummy()

results = pandas.read_json(bench.outfile.getvalue(), lines=True)
results = pandas.read_json(bench.outfile, lines=True)
assert results['return_value'][0] == str(obj)
3 changes: 2 additions & 1 deletion microbench/tests/test_line_profiler.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
from microbench import MicroBench, MBLineProfiler
import pandas
import io


def test_line_profiler():
Expand All @@ -20,7 +21,7 @@ def my_function():
for _ in range(3):
assert my_function() == 499999500000

results = pandas.read_json(lpbench.outfile.getvalue(), lines=True)
results = pandas.read_json(lpbench.outfile, lines=True)
lp = MBLineProfiler.decode_line_profile(results['line_profiler'][0])
assert lp.__class__.__name__ == 'LineStats'
MBLineProfiler.print_line_profile(results['line_profiler'][0])
Expand Down
2 changes: 1 addition & 1 deletion microbench/tests/test_nvidia.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,6 @@ def test():

test()

results = pandas.read_json(bench.outfile.getvalue(), lines=True)
results = pandas.read_json(bench.outfile, lines=True)
assert 'nvidia_gpu_name' in results.columns
assert 'nvidia_memory.total' in results.columns
2 changes: 1 addition & 1 deletion microbench/tests/test_psutil.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,6 @@ def test_func():

test_func()

results = pandas.read_json(mybench.outfile.getvalue(), lines=True)
results = pandas.read_json(mybench.outfile, lines=True)
assert results['cpu_cores_logical'][0] >= 1
assert results['ram_total'][0] > 0

0 comments on commit 1a65b77

Please sign in to comment.