A Rust library that provides injectable FileSyste, Network and Print resources to enhance the testability of your code. https://git.kemitix.net/kemitix/kxio
Find a file
Paul Campbell 8007f01d94
All checks were successful
Test / build (map[name:nightly]) (push) Successful in 8m36s
Test / build (map[name:stable]) (push) Successful in 10m10s
Release Please / Release-plz (push) Successful in 1m50s
fix(net)!: remove Drop assertions for any unused plans
Tests should use the existing `assert_no_unused_plans` method available
on both `Net` and `MockNet`.

This removes the problem of assetions being applied early when there are
multiple clones of the `Net` or `MockNet` and one of them is dropped.

feat(net): add `MockNet:;plans_left`

tests(net): add tests for MockNet::try_from
2024-12-29 19:33:27 +00:00
.cargo build: switch to forgejo actions 2024-10-29 22:30:17 +00:00
.forgejo/workflows chore(deps): update kemitix/rust action to v2.5.0 2024-12-03 20:52:56 +00:00
.git-hooks feat: initial empty library 2024-04-08 14:33:39 +01:00
examples feat(fs)!: Reader now supports non-utf8 files 2024-12-15 14:01:18 +00:00
src fix(net)!: remove Drop assertions for any unused plans 2024-12-29 19:33:27 +00:00
tests fix(net)!: remove Drop assertions for any unused plans 2024-12-29 19:33:27 +00:00
.git-next.toml build: Add .git-next.toml config file 2024-04-16 07:06:50 +01:00
.gitignore chore: ignore any occasional use of rover 2024-12-02 20:48:59 +00:00
.rgignore feat: initial empty library 2024-04-08 14:33:39 +01:00
bacon.toml feat: initial empty library 2024-04-08 14:33:39 +01:00
Cargo.toml chore: release v4.0.1 2024-12-25 19:37:18 +00:00
CHANGELOG.md chore: release v4.0.1 2024-12-25 19:37:18 +00:00
justfile feat(net): cleaner mock.on syntax 2024-11-11 21:41:32 +00:00
LICENSE feat: initial empty library 2024-04-08 14:33:39 +01:00
README.md doc(net): added 2024-11-11 22:27:42 +00:00
renovate.json chore(deps): prevent renovate creating pointless PRs 2024-04-27 14:29:48 +01:00

kxio

kxio is a Rust library that provides injectable FileSystem and Network resources to enhance the testability of your code. By abstracting system-level interactions, kxio enables easier mocking and testing of code that relies on file system and network operations.

Features

  • Filesystem Abstraction
  • Network Abstraction
  • Enhanced Testability

Filesystem

The Filesystem module offers a clean abstraction over std::fs, the standard file system operations. For comprehensive documentation and usage examples, please refer to https://docs.rs/kxio/latest/kxio/fs/.

Key Filesystem Features:

  • File reading and writing
  • Directory operations
  • File metadata access
  • Fluent API for operations like .reader().bytes()

Network

The Network module offers a testable interface over the reqwest crate. For comprehensive documentation and usage examples, please refer to https://docs.rs/kxio/latest/kxio/net/

Getting Started

Add kxio to your Cargo.toml:

[dependencies]
kxio = "x.y.z"

Usage

See the example get.rs for an annotated example on how to use the kxio library. It covers both the net and fs modules.

Development

Contributing

Contributions are welcome! Please check our issue tracker for open tasks or submit your own ideas.

License

This project is licensed under the terms specified in the LICENSE file in the repository root.

Acknowledgements

  • Built with Rust

For more information, bug reports, or feature requests, please visit our repository.