File: fix-tests-32-bit.diff

package info (click to toggle)
rust-async-zip 0.0.18-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 736 kB
  • sloc: makefile: 6
file content (58 lines) | stat: -rw-r--r-- 2,184 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
--- a/src/tests/write/zip64/mod.rs
+++ b/src/tests/write/zip64/mod.rs
@@ -14,7 +14,7 @@
 // Useful constants for writing a large file.
 const BATCH_SIZE: usize = 100_000;
 const NUM_BATCHES: usize = NON_ZIP64_MAX_SIZE as usize / BATCH_SIZE + 1;
-const BATCHED_FILE_SIZE: usize = NUM_BATCHES * BATCH_SIZE;
+const BATCHED_FILE_SIZE: u64 = NUM_BATCHES as u64 * BATCH_SIZE as u64;
 
 /// Test writing a small zip64 file.
 /// No zip64 extra fields will be emitted for EntryWhole.
@@ -50,11 +50,12 @@
 
 /// Test writing a large zip64 file. This test will use upwards of 4GB of memory.
 #[tokio::test]
+#[cfg(not(target_pointer_width="32"))]
 async fn test_write_large_zip64_file() {
     init_logger();
 
     // Allocate space with some extra for metadata records
-    let mut buffer = Vec::with_capacity(BATCHED_FILE_SIZE + 100_000);
+    let mut buffer = Vec::with_capacity((BATCHED_FILE_SIZE + 100_000).try_into().unwrap());
     let mut writer = ZipFileWriter::new(&mut buffer);
 
     // Stream-written zip files are dubiously spec-conformant. We need to specify a valid file size
@@ -95,18 +96,21 @@
         }
         bytes_total += read_bytes;
     }
-    assert_eq!(bytes_total, BATCHED_FILE_SIZE);
+    assert_eq!(bytes_total as u64, BATCHED_FILE_SIZE);
 }
 
 /// Test writing a file, and reading it with async-zip
+/// Skip this test on 32-bit architectures as it will
+/// Run out of address space.
 #[tokio::test]
+#[cfg(not(target_pointer_width="32"))]
 async fn test_write_large_zip64_file_self_read() {
     use futures_lite::io::AsyncReadExt;
 
     init_logger();
 
     // Allocate space with some extra for metadata records
-    let mut buffer = Vec::with_capacity(BATCHED_FILE_SIZE + 100_000);
+    let mut buffer = Vec::with_capacity((BATCHED_FILE_SIZE + 100_000).try_into().unwrap());
     let mut writer = ZipFileWriter::new(&mut buffer);
 
     let entry = ZipEntryBuilder::new("file".into(), Compression::Stored);
@@ -132,7 +136,7 @@
         }
         bytes_total += read_bytes;
     }
-    assert_eq!(bytes_total, BATCHED_FILE_SIZE);
+    assert_eq!(bytes_total as u64, BATCHED_FILE_SIZE);
 }
 
 /// Test writing a zip64 file with more than u16::MAX files.