-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'main' into 169-set-c-parameter-for-regularization-of-a-…
…supportvectormachine
- Loading branch information
Showing
19 changed files
with
282 additions
and
52 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
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
Binary file not shown.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
29 changes: 10 additions & 19 deletions
29
tests/safeds/data/tabular/containers/_column/test_plot_boxplot.py
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 |
---|---|---|
@@ -1,29 +1,20 @@ | ||
import _pytest | ||
import matplotlib.pyplot as plt | ||
import pytest | ||
from safeds.data.image.containers import Image | ||
from safeds.data.tabular.containers import Table | ||
from safeds.data.tabular.exceptions import NonNumericColumnError | ||
|
||
from tests.helpers import resolve_resource_path | ||
|
||
def test_plot_boxplot_complex() -> None: | ||
with pytest.raises(NotImplementedError): # noqa: PT012 | ||
table = Table.from_dict({"A": [1, 2, complex(1, -2)]}) | ||
table.get_column("A").plot_boxplot() | ||
|
||
def test_should_match_snapshot() -> None: | ||
table = Table.from_dict({"A": [1, 2, 3]}) | ||
table.get_column("A").plot_boxplot() | ||
current = table.get_column("A").plot_boxplot() | ||
snapshot = Image.from_png_file(resolve_resource_path("./image/snapshot_boxplot.png")) | ||
assert snapshot._image.tobytes() == current._image.tobytes() | ||
|
||
|
||
def test_plot_boxplot_non_numeric() -> None: | ||
def test_should_raise_if_column_contains_non_numerical_values() -> None: | ||
table = Table.from_dict({"A": [1, 2, "A"]}) | ||
with pytest.raises(NonNumericColumnError): | ||
table.get_column("A").plot_boxplot() | ||
|
||
|
||
def test_plot_boxplot_float(monkeypatch: _pytest.monkeypatch) -> None: | ||
monkeypatch.setattr(plt, "show", lambda: None) | ||
table = Table.from_dict({"A": [1, 2, 3.5]}) | ||
table.get_column("A").plot_boxplot() | ||
|
||
|
||
def test_plot_boxplot_int(monkeypatch: _pytest.monkeypatch) -> None: | ||
monkeypatch.setattr(plt, "show", lambda: None) | ||
table = Table.from_dict({"A": [1, 2, 3]}) | ||
table.get_column("A").plot_boxplot() |
19 changes: 14 additions & 5 deletions
19
tests/safeds/data/tabular/containers/_column/test_plot_histogram.py
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 |
---|---|---|
@@ -1,9 +1,18 @@ | ||
import _pytest | ||
import matplotlib.pyplot as plt | ||
from safeds.data.image.containers import Image | ||
from safeds.data.tabular.containers import Table | ||
|
||
from tests.helpers import resolve_resource_path | ||
|
||
def test_plot_histogram(monkeypatch: _pytest.monkeypatch) -> None: | ||
monkeypatch.setattr(plt, "show", lambda: None) | ||
|
||
def test_should_match_snapshot_numeric() -> None: | ||
table = Table.from_dict({"A": [1, 2, 3]}) | ||
table.get_column("A").plot_histogram() | ||
current = table.get_column("A").plot_histogram() | ||
snapshot = Image.from_png_file(resolve_resource_path("./image/snapshot_histogram_numeric.png")) | ||
assert snapshot._image.tobytes() == current._image.tobytes() | ||
|
||
|
||
def test_should_match_snapshot_str() -> None: | ||
table = Table.from_dict({"A": ["A", "B", "Apple"]}) | ||
current = table.get_column("A").plot_histogram() | ||
snapshot = Image.from_png_file(resolve_resource_path("./image/snapshot_histogram_str.png")) | ||
assert snapshot._image.tobytes() == current._image.tobytes() |
40 changes: 40 additions & 0 deletions
40
tests/safeds/data/tabular/containers/_table/test_from_excel_file.py
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,40 @@ | ||
from pathlib import Path | ||
|
||
import pytest | ||
from safeds.data.tabular.containers import Table | ||
|
||
from tests.helpers import resolve_resource_path | ||
|
||
|
||
@pytest.mark.parametrize( | ||
("path", "expected"), | ||
[ | ||
( | ||
resolve_resource_path("./dummy_excel_file.xlsx"), | ||
Table.from_dict( | ||
{ | ||
"A": [1], | ||
"B": [2], | ||
}, | ||
), | ||
), | ||
( | ||
Path(resolve_resource_path("./dummy_excel_file.xlsx")), | ||
Table.from_dict( | ||
{ | ||
"A": [1], | ||
"B": [2], | ||
}, | ||
), | ||
), | ||
], | ||
ids=["string path", "object path"], | ||
) | ||
def test_should_create_table_from_excel_file(path: str | Path, expected: Table) -> None: | ||
table = Table.from_excel_file(path) | ||
assert table == expected | ||
|
||
|
||
def test_should_raise_if_file_not_found() -> None: | ||
with pytest.raises(FileNotFoundError): | ||
Table.from_excel_file(resolve_resource_path("test_table_from_excel_file_invalid.xls")) |
18 changes: 7 additions & 11 deletions
18
tests/safeds/data/tabular/containers/_table/test_plot_correlation_heatmap.py
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 |
---|---|---|
@@ -1,15 +1,11 @@ | ||
import _pytest | ||
import matplotlib.pyplot as plt | ||
from safeds.data.image.containers import Image | ||
from safeds.data.tabular.containers import Table | ||
|
||
from tests.helpers import resolve_resource_path | ||
|
||
def test_plot_correlation_heatmap_non_numeric(monkeypatch: _pytest.monkeypatch) -> None: | ||
monkeypatch.setattr(plt, "show", lambda: None) | ||
table = Table.from_dict({"A": [1, 2, "A"], "B": [1, 2, 3]}) | ||
table.plot_correlation_heatmap() | ||
|
||
|
||
def test_plot_correlation_heatmap(monkeypatch: _pytest.monkeypatch) -> None: | ||
monkeypatch.setattr(plt, "show", lambda: None) | ||
table = Table.from_dict({"A": [1, 2, 3.5], "B": [2, 4, 7]}) | ||
table.plot_correlation_heatmap() | ||
def test_should_match_snapshot() -> None: | ||
table = Table.from_dict({"A": [1, 2, 3.5], "B": [0.2, 4, 77]}) | ||
current = table.plot_correlation_heatmap() | ||
legacy = Image.from_png_file(resolve_resource_path("./image/snapshot_heatmap.png")) | ||
assert legacy._image.tobytes() == current._image.tobytes() |
14 changes: 8 additions & 6 deletions
14
tests/safeds/data/tabular/containers/_table/test_plot_lineplot.py
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 |
---|---|---|
@@ -1,17 +1,19 @@ | ||
import _pytest | ||
import matplotlib.pyplot as plt | ||
import pytest | ||
from safeds.data.image.containers import Image | ||
from safeds.data.tabular.containers import Table | ||
from safeds.data.tabular.exceptions import UnknownColumnNameError | ||
|
||
from tests.helpers import resolve_resource_path | ||
|
||
def test_plot_lineplot(monkeypatch: _pytest.monkeypatch) -> None: | ||
monkeypatch.setattr(plt, "show", lambda: None) | ||
|
||
def test_should_match_snapshot() -> None: | ||
table = Table.from_dict({"A": [1, 2, 3], "B": [2, 4, 7]}) | ||
table.plot_lineplot("A", "B") | ||
current = table.plot_lineplot("A", "B") | ||
snapshot = Image.from_png_file(resolve_resource_path("./image/snapshot_lineplot.png")) | ||
assert snapshot._image.tobytes() == current._image.tobytes() | ||
|
||
|
||
def test_plot_lineplot_wrong_column_name() -> None: | ||
def test_should_raise_if_column_does_not_exist() -> None: | ||
table = Table.from_dict({"A": [1, 2, 3], "B": [2, 4, 7]}) | ||
with pytest.raises(UnknownColumnNameError): | ||
table.plot_lineplot("C", "A") |
14 changes: 8 additions & 6 deletions
14
tests/safeds/data/tabular/containers/_table/test_plot_scatterplot.py
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 |
---|---|---|
@@ -1,17 +1,19 @@ | ||
import _pytest | ||
import matplotlib.pyplot as plt | ||
import pytest | ||
from safeds.data.image.containers import Image | ||
from safeds.data.tabular.containers import Table | ||
from safeds.data.tabular.exceptions import UnknownColumnNameError | ||
|
||
from tests.helpers import resolve_resource_path | ||
|
||
def test_plot_scatterplot(monkeypatch: _pytest.monkeypatch) -> None: | ||
monkeypatch.setattr(plt, "show", lambda: None) | ||
|
||
def test_should_match_snapshot() -> None: | ||
table = Table.from_dict({"A": [1, 2, 3], "B": [2, 4, 7]}) | ||
table.plot_scatterplot("A", "B") | ||
current = table.plot_scatterplot("A", "B") | ||
snapshot = Image.from_png_file(resolve_resource_path("./image/snapshot_scatterplot.png")) | ||
assert snapshot._image.tobytes() == current._image.tobytes() | ||
|
||
|
||
def test_plot_scatterplot_wrong_column_name() -> None: | ||
def test_should_raise_if_column_does_not_exist() -> None: | ||
table = Table.from_dict({"A": [1, 2, 3], "B": [2, 4, 7]}) | ||
with pytest.raises(UnknownColumnNameError): | ||
table.plot_scatterplot("C", "A") |
26 changes: 26 additions & 0 deletions
26
tests/safeds/data/tabular/containers/_table/test_to_excel_file.py
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,26 @@ | ||
from pathlib import Path | ||
from tempfile import NamedTemporaryFile | ||
|
||
from safeds.data.tabular.containers import Table | ||
|
||
|
||
def test_should_create_csv_file_from_table_by_str() -> None: | ||
table = Table.from_dict({"col1": ["col1_1"], "col2": ["col2_1"]}) | ||
with NamedTemporaryFile(suffix=".xlsx") as tmp_table_file: | ||
tmp_table_file.close() | ||
with Path(tmp_table_file.name).open("w", encoding="utf-8") as tmp_file: | ||
table.to_excel_file(tmp_file.name) | ||
with Path(tmp_table_file.name).open("r", encoding="utf-8") as tmp_file: | ||
table_r = Table.from_excel_file(tmp_file.name) | ||
assert table == table_r | ||
|
||
|
||
def test_should_create_csv_file_from_table_by_path() -> None: | ||
table = Table.from_dict({"col1": ["col1_1"], "col2": ["col2_1"]}) | ||
with NamedTemporaryFile(suffix=".xlsx") as tmp_table_file: | ||
tmp_table_file.close() | ||
with Path(tmp_table_file.name).open("w", encoding="utf-8") as tmp_file: | ||
table.to_excel_file(Path(tmp_file.name)) | ||
with Path(tmp_table_file.name).open("r", encoding="utf-8") as tmp_file: | ||
table_r = Table.from_excel_file(Path(tmp_file.name)) | ||
assert table == table_r |
Oops, something went wrong.