geddes 0.2.0

A Rust library for parsing XRD pattern files
Documentation
from pathlib import Path

import geddes

ROOT = Path(__file__).resolve().parents[1]
DATA_DIR = ROOT / "tests" / "data"


def _assert_pattern(pattern):
    """Validate basic invariants for a loaded pattern object."""
    assert len(pattern.x) > 0
    assert len(pattern.x) == len(pattern.y)
    if pattern.e is not None:
        assert len(pattern.e) == len(pattern.x)


def test_01_read_gsas_raw():
    """Load a GSAS RAW file by path."""
    path = DATA_DIR / "gsas_raw" / "gsas.raw"
    pattern = geddes.read(str(path))
    _assert_pattern(pattern)


def test_02_read_rasx():
    """Load a RASX archive by path."""
    path = DATA_DIR / "rasx" / "sample.rasx"
    pattern = geddes.read(str(path))
    _assert_pattern(pattern)


def test_03_read_xrdml():
    """Load an XRDML file by path."""
    path = DATA_DIR / "xrdml" / "sample.xrdml"
    pattern = geddes.read(str(path))
    _assert_pattern(pattern)


def test_04_read_xy():
    """Load an XY file by path."""
    path = DATA_DIR / "xy" / "sample.xy"
    pattern = geddes.read(str(path))
    _assert_pattern(pattern)


def test_05_read_csv():
    """Load a CSV file by path."""
    path = DATA_DIR / "csv" / "sample.csv"
    pattern = geddes.read(str(path))
    _assert_pattern(pattern)


def test_06_read_bytes_gsas_raw():
    """Load GSAS RAW data from bytes."""
    path = DATA_DIR / "gsas_raw" / "gsas.raw"
    data = path.read_bytes()
    pattern = geddes.read_bytes(data, "gsas.raw")
    _assert_pattern(pattern)


def test_07_read_bytes_rasx():
    """Load RASX data from bytes."""
    path = DATA_DIR / "rasx" / "sample.rasx"
    data = path.read_bytes()
    pattern = geddes.read_bytes(data, "sample.rasx")
    _assert_pattern(pattern)


def test_08_read_bytes_xrdml():
    """Load XRDML data from bytes."""
    path = DATA_DIR / "xrdml" / "sample.xrdml"
    data = path.read_bytes()
    pattern = geddes.read_bytes(data, "sample.xrdml")
    _assert_pattern(pattern)


def test_09_read_bytes_xy():
    """Load XY data from bytes."""
    path = DATA_DIR / "xy" / "sample.xy"
    data = path.read_bytes()
    pattern = geddes.read_bytes(data, "sample.xy")
    _assert_pattern(pattern)


def test_10_read_bytes_csv():
    """Load CSV data from bytes."""
    path = DATA_DIR / "csv" / "sample.csv"
    data = path.read_bytes()
    pattern = geddes.read_bytes(data, "sample.csv")
    _assert_pattern(pattern)