#144534 Report by node gh-actions covering 2230 tests from 61 modules resulted into 1 error

Report

ObsPy version
1.4.2.post0+355.ge5cc93e0bf
GitHub Pull Request
https://github.com/obspy/obspy/pull/3589
Report file
JSON document
Total runtime
267.9 sec
Report date/time
July 24, 2025, 9:18 a.m.

System / Python

Architecture
64bit
Machine
AMD64
Node
gh-actions
Processor
AMD64 Family 25 Model 1 Stepping 1, AuthenticAMD
Python Compiler
MSC v.1929 64 bit (AMD64)
Python Implementation
CPython
Python Version
3.8.20
Release
10
System
Windows
Version
10.0.20348

Dependencies

cartopy
0.21.1
decorator
5.1.1
flake8
---
geographiclib
2.0
lxml
5.3.0
matplotlib
3.3.4
numpy
1.20.3
obspy
1.4.2.post0+355.ge5cc93e0bf
pyproj
3.5.0
pytest
8.3.4
pytest-json-report
1.5.0
requests
2.32.3
scipy
1.7.3
setuptools
75.3.0
shapefile
---
sqlalchemy
1.4.49

Modules (61)

Module Errors / Failures Tracebacks
obspy.clients.earthworm Not tested -
obspy.clients.fdsn - -
obspy.clients.filesystem - -
obspy.clients.iris Not tested -
obspy.clients.neic Not tested -
obspy.clients.nrl - -
obspy.clients.seedlink - -
obspy.clients.syngine Not tested -
obspy.core - -
obspy.core.event - -
obspy.core.inventory - -
obspy.core.util - -
obspy.geodetics - -
obspy.imaging - -
obspy.io.ah - -
obspy.io.alsep - -
obspy.io.arclink - -
obspy.io.ascii - -
obspy.io.cmtsolution - -
obspy.io.cnv - -
obspy.io.css - -
obspy.io.csv - -
obspy.io.cybershake - -
obspy.io.dmx - -
obspy.io.focmec - -
obspy.io.gcf - -
obspy.io.gse2 - -
obspy.io.hypodd - -
obspy.io.iaspei - -
obspy.io.json - -
obspy.io.kinemetrics - -
obspy.io.kml - -
obspy.io.mseed - -
obspy.io.ndk - -
obspy.io.nied - -
obspy.io.nlloc - -
obspy.io.nordic - -
obspy.io.pdas - -
obspy.io.pde - -
obspy.io.quakeml - -
obspy.io.reftek - -
obspy.io.rg16 - -
obspy.io.sac - -
obspy.io.scardec - -
obspy.io.seg2 - -
obspy.io.segy - -
obspy.io.seisan - -
obspy.io.seiscomp - -
obspy.io.sh - -
obspy.io.shapefile - -
obspy.io.stationtxt - -
obspy.io.stationxml - -
obspy.io.wav - -
obspy.io.win - -
obspy.io.xseed - -
obspy.io.y - -
obspy.io.zmap - -
obspy.realtime - -
obspy.scripts - -
obspy.signal 1 1
obspy.taup - -
Summary 1 1

Tracebacks (1)

Traceback (most recent call last):
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\_pytest\runner.py", line 341, in from_call
result: TResult | None = func()
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\_pytest\runner.py", line 242, in <lambda>
lambda: runtest_hook(item=item, **kwds), when=when, reraise=reraise
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\pluggy\_hooks.py", line 513, in __call__
return self._hookexec(self.name, self._hookimpls.copy(), kwargs, firstresult)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\pluggy\_manager.py", line 120, in _hookexec
return self._inner_hookexec(hook_name, methods, kwargs, firstresult)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\pluggy\_callers.py", line 182, in _multicall
return outcome.get_result()
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\pluggy\_result.py", line 100, in get_result
raise exc.with_traceback(exc.__traceback__)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\pluggy\_callers.py", line 167, in _multicall
teardown.throw(outcome._exception)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\_pytest\threadexception.py", line 92, in pytest_runtest_call
yield from thread_exception_runtest_hook()
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\_pytest\threadexception.py", line 68, in thread_exception_runtest_hook
yield
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\pluggy\_callers.py", line 167, in _multicall
teardown.throw(outcome._exception)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\_pytest\unraisableexception.py", line 95, in pytest_runtest_call
yield from unraisable_exception_runtest_hook()
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\_pytest\unraisableexception.py", line 70, in unraisable_exception_runtest_hook
yield
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\pluggy\_callers.py", line 167, in _multicall
teardown.throw(outcome._exception)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\_pytest\logging.py", line 846, in pytest_runtest_call
yield from self._runtest_for(item, "call")
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\_pytest\logging.py", line 829, in _runtest_for
yield
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\pluggy\_callers.py", line 167, in _multicall
teardown.throw(outcome._exception)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\_pytest\capture.py", line 880, in pytest_runtest_call
return (yield)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\pluggy\_callers.py", line 167, in _multicall
teardown.throw(outcome._exception)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\_pytest\skipping.py", line 257, in pytest_runtest_call
return (yield)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\pluggy\_callers.py", line 103, in _multicall
res = hook_impl.function(*args)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\_pytest\runner.py", line 174, in pytest_runtest_call
item.runtest()
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\_pytest\python.py", line 1627, in runtest
self.ihook.pytest_pyfunc_call(pyfuncitem=self)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\pluggy\_hooks.py", line 513, in __call__
return self._hookexec(self.name, self._hookimpls.copy(), kwargs, firstresult)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\pluggy\_manager.py", line 120, in _hookexec
return self._inner_hookexec(hook_name, methods, kwargs, firstresult)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\pluggy\_callers.py", line 139, in _multicall
raise exception.with_traceback(exception.__traceback__)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\pluggy\_callers.py", line 103, in _multicall
res = hook_impl.function(*args)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\_pytest\python.py", line 159, in pytest_pyfunc_call
result = testfunction(**testargs)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\signal\tests\test_spectral_estimation.py", line 359, in test_ppsd_w_iris_against_obspy_results
ppsd = PPSD(st[0].stats, metadata)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\signal\spectral_estimation.py", line 474, in __init__
self.responses = self._preload_responses()
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\signal\spectral_estimation.py", line 645, in _preload_responses
inv = read_inventory(self.metadata)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\decorator.py", line 232, in fun
return caller(func, *(extras + args), **kw)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\core\util\decorator.py", line 298, in _map_example_filename
return func(*args, **kwargs)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\core\inventory\inventory.py", line 91, in read_inventory
return _generic_reader(path_or_file_object, _read, format=format,
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\core\util\base.py", line 625, in _generic_reader
return callback_func(pathname_or_url, **kwargs)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\decorator.py", line 232, in fun
return caller(func, *(extras + args), **kw)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\core\util\decorator.py", line 143, in uncompress_file
return func(filename, *args, **kwargs)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\core\inventory\inventory.py", line 100, in _read
inventory, format = _read_from_plugin('inventory', filename, format=format,
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\core\util\base.py", line 400, in _read_from_plugin
is_format = is_format(filename)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\io\stationxml\core.py", line 84, in _is_stationxml
xmldoc = etree.parse(path_or_file_object)
File "src/lxml/etree.pyx", line 3589, in lxml.etree.parse
File "src/lxml/parser.pxi", line 1979, in lxml.etree._parseDocument
File "src/lxml/parser.pxi", line 1999, in lxml.etree._parseFilelikeDocument
File "src/lxml/parser.pxi", line 1893, in lxml.etree._parseDocFromFilelike
File "src/lxml/parser.pxi", line 1224, in lxml.etree._BaseParser._parseDocFromFilelike
File "src/lxml/parser.pxi", line 633, in lxml.etree._ParserContext._handleParseResultDoc
File "src/lxml/parser.pxi", line 739, in lxml.etree._handleParseResult
File "src/lxml/etree.pyx", line 351, in lxml.etree._ExceptionContext._raise_if_stored
File "src/lxml/parser.pxi", line 384, in lxml.etree._FileReaderContext.copyToBuffer
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\decorator.py", line 232, in fun
return caller(func, *(extras + args), **kw)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\core\util\decorator.py", line 298, in _map_example_filename
return func(*args, **kwargs)
File "C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\io\xseed\parser.py", line 213, in read
raise TypeError
TypeError

Skipped tests (22)

Submodule Test Skip message
core core/stream.py::obspy.core.stream._is_pickle Skipped: all tests skipped by +SKIP option
core.util core/util/misc.py::obspy.core.util.misc.CatchOutput Skipped: all tests skipped by +SKIP option
core.util core/util/misc.py::obspy.core.util.misc.SuppressOutput Skipped: all tests skipped by +SKIP option
core.util core/util/misc.py::obspy.core.util.misc.TemporaryWorkingDirectory Skipped: all tests skipped by +SKIP option
geodetics geodetics/tests/test_util_geodetics.py::TestUtilGeodetics::test_gps_2_dist_azimuth_bug150 Skipped: Geographiclib installed, not using calc_vincenty_inverse
imaging imaging/tests/test_mopad_script.py::TestMopad::test_script_plot Skipped: Currently broken until further review.
imaging imaging/tests/test_scan.py::TestScan::test_scan_dir_no_permission Skipped: unable to remove read permission from a test file for testing purposes
io.ascii io/ascii/core.py::obspy.io.ascii.core._is_slist Skipped: all tests skipped by +SKIP option
io.ascii io/ascii/core.py::obspy.io.ascii.core._is_tspair Skipped: all tests skipped by +SKIP option
io.gcf io/gcf/core.py::obspy.io.gcf.core._write_gcf Skipped: all tests skipped by +SKIP option
io.nordic io/nordic/utils.py::obspy.io.nordic.utils._evmagtonor Skipped: all tests skipped by +SKIP option
io.nordic io/nordic/utils.py::obspy.io.nordic.utils._nortoevmag Skipped: all tests skipped by +SKIP option
io.pde io/pde/mchedr.py::obspy.io.pde.mchedr._is_mchedr Skipped: all tests skipped by +SKIP option
io.quakeml io/quakeml/core.py::obspy.io.quakeml.core._is_quakeml Skipped: all tests skipped by +SKIP option
io.seisan io/seisan/core.py::obspy.io.seisan.core._is_seisan Skipped: all tests skipped by +SKIP option
io.sh io/sh/core.py::obspy.io.sh.core._is_asc Skipped: all tests skipped by +SKIP option
io.sh io/sh/core.py::obspy.io.sh.core._is_q Skipped: all tests skipped by +SKIP option
io.wav io/wav/core.py::obspy.io.wav.core._is_wav Skipped: all tests skipped by +SKIP option
io.y io/y/core.py::obspy.io.y.core._is_y Skipped: all tests skipped by +SKIP option
signal signal/quality_control.py::obspy.signal.quality_control.MSEEDMetadata Skipped: all tests skipped by +SKIP option
signal signal/tests/test_invsim.py::TestInvSim::test_evalresp_file_like_object Skipped: unreproducible test fail encountered on Appveyor sometimes.
signal signal/tests/test_quality_control.py::TestQualityControl::test_schema_validation Skipped: Test requires the jsonschema module

Slowest tests (20)

Runtime Test
10.434s io/xseed/tests/test_core.py::TestCore::test_response_calculation_from_seed_and_xseed
7.295s core/tests/test_event.py::TestEvent::test_plot_farfield_without_quiver_with_maps
5.582s imaging/tests/test_ppsd.py::TestPPSD::test_ppsd_plot
5.499s taup/tests/test_tau.py::TestTauPyModel::test_regional_models
5.397s taup/tests/test_seismic_phase.py::TestTauPySeismicPhase::test_shoot_existing_ray_param
5.382s taup/__init__.py::obspy.taup
4.973s signal/tests/test_spectral_estimation.py::TestPsd::test_ppsd
3.344s io/arclink/tests/test_inventory_xml.py::TestArclinkInventory::test_auto_read_arclink_xml
2.734s core/stream.py::obspy.core.stream.read
2.474s taup/tests/test_tau.py::TestTauPyModel::test_vs_java_iasp91
2.455s signal/tests/test_cross_correlation.py::TestCrossCorrelation::test_correlate_stream_template_and_correlation_detector
2.431s signal/tests/test_calibration.py::TestCalibration::test_relcal_different_overlaps
2.287s taup/tests/test_seismic_phase.py::TestTauPySeismicPhase::test_many_identically_named_phases
2.248s signal/tests/test_polarization.py::TestPolarization::test_polarization_vidale
2.231s core/tests/test_inventory.py::TestInventoryCartopy::test_location_plot_local
2.175s core/tests/test_trace.py::TestTrace::test_remove_response_plot
2.101s taup/tests/test_velocity_model.py::TestTauPyVelocityModel::test_read_velocity_model
2.010s signal/tests/test_spectral_estimation.py::TestPsd::test_ppsd_restricted_stacks
1.878s core/tests/test_inventory.py::TestInventoryCartopy::test_location_plot_global
1.687s io/alsep/tests/test_alsep.py::TestAlsep::test_read_alsep_pse_file_with_ignore_error

Warnings (3)

Stage Filename Category Message
runtest C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\io\xseed\parser.py:172 UserWarning Clearing parser before every subsequent read()
runtest C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\core\util\misc.py:399 UserWarning PermissionError(13, 'Access is denied')
runtest C:\Users\runneradmin\miniconda3\envs\test\lib\site-packages\obspy\signal\spectral_estimation.py:699 UserWarning Could not get response: error Can not use evalresp on response with no response stages.