# NetHSM containerized tests
Containerized testing environments for NetHSM related projects.
This project contains types which start virtual NetHSM instances using Podman.
## Documentation
- <https://signstar.archlinux.page/rustdoc/nethsm_tests/> for development version of the crate
- <https://docs.rs/nethsm_tests/latest/nethsm_tests/> for released versions of the crate
## Example
The following integration test starts a NetHSM container with users to retrieve several random bytes:
```rust no_run
use nethsm::Credentials;
use nethsm::NetHsm;
use nethsm::Passphrase;
use nethsm_tests::nethsm_with_users;
use nethsm_tests::NetHsmImage;
use nethsm_tests::DEFAULT_OPERATOR_USER_ID;
use nethsm_tests::DEFAULT_OPERATOR_USER_PASSPHRASE;
use rustainers::Container;
use testresult::TestResult;
pub static LENGTH: u32 = 32;
#[ignore = "requires Podman"]
#[rstest::rstest]
#[tokio::test]
async fn get_random_bytes(
#[future] nethsm_with_users: TestResult<(NetHsm, Container<NetHsmImage>)>,
) -> TestResult {
let (nethsm, _container) = nethsm_with_users.await?;
nethsm.add_credentials(Credentials::new(
DEFAULT_OPERATOR_USER_ID.parse()?,
Some(Passphrase::new(
DEFAULT_OPERATOR_USER_PASSPHRASE.to_string(),
)),
));
nethsm.use_credentials(&DEFAULT_OPERATOR_USER_ID.parse()?)?;
let random_message = nethsm.random(LENGTH)?;
println!("A random message from the NetHSM: {:#?}", random_message);
assert_eq!(usize::try_from(LENGTH)?, random_message.len(),);
Ok(())
}
```
## Contributing
Please refer to the [contributing guidelines] to learn how to contribute to this project.
## License
This project may be used under the terms of the [Apache-2.0] or [MIT] license.
Changes to this project - unless stated otherwise - automatically fall under the terms of both of the aforementioned licenses.
[Apache-2.0]: https://www.apache.org/licenses/LICENSE-2.0
[MIT]: https://opensource.org/licenses/MIT
[contributing guidelines]: ../CONTRIBUTING.md