Skip to content

Commit

Permalink
Add a test to EncoderStringWriter
Browse files Browse the repository at this point in the history
Making sure that
#247 is not actually
a bug.
  • Loading branch information
marshallpierce committed Aug 26, 2023
1 parent 70d2b53 commit fa9e406
Showing 1 changed file with 40 additions and 9 deletions.
49 changes: 40 additions & 9 deletions src/write/encoder_string_writer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -44,11 +44,6 @@ use std::io;
/// assert_eq!("base64: YXNkZg==", &buf);
/// ```
///
/// # Panics
///
/// Calling `write()` (or related methods) or `finish()` after `finish()` has completed without
/// error is invalid and will panic.
///
/// # Performance
///
/// Because it has to validate that the base64 is UTF-8, it is about 80% as fast as writing plain
Expand Down Expand Up @@ -141,9 +136,12 @@ impl<S: StrConsumer> io::Write for Utf8SingleCodeUnitWriter<S> {
#[cfg(test)]
mod tests {
use crate::{
engine::Engine, tests::random_engine, write::encoder_string_writer::EncoderStringWriter,
engine::{general_purpose::STANDARD, Engine},
tests::random_engine,
write::encoder_string_writer::EncoderStringWriter,
};
use rand::Rng;
use std::cmp;
use std::io::Write;

#[test]
Expand All @@ -158,9 +156,8 @@ mod tests {
orig_data.clear();
normal_encoded.clear();

for _ in 0..size {
orig_data.push(rng.gen());
}
orig_data.resize(size, 0);
rng.fill(&mut orig_data[..]);

let engine = random_engine(&mut rng);
engine.encode_string(&orig_data, &mut normal_encoded);
Expand All @@ -172,6 +169,40 @@ mod tests {

let stream_encoded = stream_encoder.into_inner();

assert_eq!(normal_encoded, stream_encoded);
}
}
#[test]
fn incremental_writes() {
let mut rng = rand::thread_rng();
let mut orig_data = Vec::<u8>::new();
let mut normal_encoded = String::new();

let size = 5_000;

for _ in 0..size {
orig_data.clear();
normal_encoded.clear();

orig_data.resize(size, 0);
rng.fill(&mut orig_data[..]);

let engine = random_engine(&mut rng);
engine.encode_string(&orig_data, &mut normal_encoded);

let mut stream_encoder = EncoderStringWriter::new(&engine);
// write small nibbles of data
let mut offset = 0;
while offset < size {
let nibble_size = cmp::min(rng.gen_range(0..=64), size - offset);
let len = stream_encoder
.write(&orig_data[offset..offset + nibble_size])
.unwrap();
offset += len;
}

let stream_encoded = stream_encoder.into_inner();

assert_eq!(normal_encoded, stream_encoded);
}
}
Expand Down

0 comments on commit fa9e406

Please sign in to comment.