velvia commented on a change in pull request #8688: URL: https://github.com/apache/arrow/pull/8688#discussion_r528960800
########## File path: rust/arrow/src/compute/kernels/boolean.rs ########## @@ -457,4 +517,42 @@ mod tests { assert_eq!(true, res.value(2)); assert_eq!(false, res.value(3)); } + + fn assert_array_eq<T: ArrowNumericType>( + expected: PrimitiveArray<T>, + actual: ArrayRef, + ) { + let actual = actual + .as_any() + .downcast_ref::<PrimitiveArray<T>>() + .expect("Actual array should unwrap to type of expected array"); + + for i in 0..expected.len() { + if expected.is_null(i) { + assert!(actual.is_null(i)); + } else { + assert_eq!(expected.value(i), actual.value(i)); + } + } + } + Review comment: Thanks everyone for their comments. It seems to me that taking a slice of the data buffer could potentially be even more expensive than shifting the null buffer, if one is not able to take a cheap slice clone (ie bits are not aligned) - but perhaps this is not common since most types are 8/16/32 bits wide. It is easier to implement for now, so I will try @jhorstmann 's suggestion using `bit_slice()` on the data buffers - would rather get in something that works sooner and iterate later when @vertexclique 's PR is merged. ---------------------------------------------------------------- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. For queries about this service, please contact Infrastructure at: us...@infra.apache.org