All checks were successful
		
		
	
	Build and test / Clippy (pull_request) Successful in 44s
				
			Build and test / Tests (pull_request) Successful in 48s
				
			Checking yaml / Run yamllint (pull_request) Successful in 5s
				
			Checking Renovate configuration / validate (pull_request) Successful in 1m4s
				
			Build and test / Build AMD64 (pull_request) Successful in 49s
				
			Build and test / Generate Documentation (pull_request) Successful in 59s
				
			
		
			
				
	
	
		
			96 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
use std::fs::File;
 | 
						|
use std::io::Read;
 | 
						|
 | 
						|
use cbz2pdf::formats::cbz::CbzWriter;
 | 
						|
use cbz2pdf::formats::FormatWriter;
 | 
						|
use cbz2pdf::model::{Document, ImagePage};
 | 
						|
 | 
						|
fn make_tiny_jpeg() -> (Vec<u8>, image::DynamicImage) {
 | 
						|
    let img = image::DynamicImage::new_rgb8(1, 1).to_rgb8();
 | 
						|
    let mut buf = Vec::new();
 | 
						|
    {
 | 
						|
        let mut cursor = std::io::Cursor::new(&mut buf);
 | 
						|
        let mut enc = image::codecs::jpeg::JpegEncoder::new_with_quality(&mut cursor, 80);
 | 
						|
        enc.encode(&img, 1, 1, image::ColorType::Rgb8.into())
 | 
						|
            .unwrap();
 | 
						|
    }
 | 
						|
    let decoded = image::load_from_memory(&buf).unwrap();
 | 
						|
    (buf, decoded)
 | 
						|
}
 | 
						|
 | 
						|
#[test]
 | 
						|
fn cbz_writer_preserves_dct_and_renames_non_jpg() {
 | 
						|
    // Prepare a page with original JPEG DCT data but a non-jpg name.
 | 
						|
    let (jpeg_dct, decoded) = make_tiny_jpeg();
 | 
						|
    let page = ImagePage {
 | 
						|
        name: "cover.png".to_string(),
 | 
						|
        image: decoded,
 | 
						|
        jpeg_dct: Some(jpeg_dct.clone()),
 | 
						|
    };
 | 
						|
    let doc = Document::new(vec![page]);
 | 
						|
 | 
						|
    let temp_dir = tempfile::tempdir().expect("create temp dir");
 | 
						|
    let cbz_path = temp_dir.path().join("out.cbz");
 | 
						|
 | 
						|
    let writer = CbzWriter;
 | 
						|
    writer.write(&doc, &cbz_path).expect("write cbz");
 | 
						|
 | 
						|
    // Open the CBZ and verify it contains 001.jpg with the exact JPEG data.
 | 
						|
    let f = File::open(&cbz_path).unwrap();
 | 
						|
    let mut zip = zip::ZipArchive::new(f).unwrap();
 | 
						|
 | 
						|
    // There should be exactly one file named 001.jpg
 | 
						|
    let mut found = false;
 | 
						|
    for i in 0..zip.len() {
 | 
						|
        let mut file = zip.by_index(i).unwrap();
 | 
						|
        let name = file.enclosed_name().unwrap().to_owned();
 | 
						|
        if name.file_name().unwrap() == "001.jpg" {
 | 
						|
            let mut data = Vec::new();
 | 
						|
            file.read_to_end(&mut data).unwrap();
 | 
						|
            assert_eq!(
 | 
						|
                data, jpeg_dct,
 | 
						|
                "writer should preserve original JPEG DCT bytes"
 | 
						|
            );
 | 
						|
            found = true;
 | 
						|
        }
 | 
						|
    }
 | 
						|
    assert!(found, "001.jpg not found in zip");
 | 
						|
}
 | 
						|
 | 
						|
#[test]
 | 
						|
fn cbz_writer_keeps_jpg_name() {
 | 
						|
    // If the page already has a .jpg name, the writer should keep it.
 | 
						|
    let (jpeg_dct, decoded) = make_tiny_jpeg();
 | 
						|
    let page = ImagePage {
 | 
						|
        name: "page01.jpg".to_string(),
 | 
						|
        image: decoded,
 | 
						|
        jpeg_dct: Some(jpeg_dct),
 | 
						|
    };
 | 
						|
    let doc = Document::new(vec![page]);
 | 
						|
 | 
						|
    let temp_dir = tempfile::tempdir().expect("create temp dir");
 | 
						|
    let cbz_path = temp_dir.path().join("out.cbz");
 | 
						|
 | 
						|
    let writer = CbzWriter;
 | 
						|
    writer.write(&doc, &cbz_path).expect("write cbz");
 | 
						|
 | 
						|
    let f = File::open(&cbz_path).unwrap();
 | 
						|
    let mut zip = zip::ZipArchive::new(f).unwrap();
 | 
						|
 | 
						|
    let mut names = Vec::new();
 | 
						|
    for i in 0..zip.len() {
 | 
						|
        let file = zip.by_index(i).unwrap();
 | 
						|
        let name = file
 | 
						|
            .enclosed_name()
 | 
						|
            .unwrap()
 | 
						|
            .file_name()
 | 
						|
            .unwrap()
 | 
						|
            .to_owned();
 | 
						|
        names.push(name.to_string_lossy().to_string());
 | 
						|
    }
 | 
						|
    assert_eq!(
 | 
						|
        names,
 | 
						|
        vec!["page01.jpg"],
 | 
						|
        "existing .jpg name should be kept"
 | 
						|
    );
 | 
						|
}
 |