blob: b4bfc42cab2ac7082e161e098b52c9ee60da67b1 [file] [log] [blame]
// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.
#![allow(clippy::approx_constant)]
extern crate parquet;
#[macro_use]
extern crate parquet_derive;
use parquet::record::RecordWriter;
#[derive(ParquetRecordWriter)]
struct ACompleteRecord<'a> {
pub a_bool: bool,
pub a_str: &'a str,
pub a_string: String,
pub a_borrowed_string: &'a String,
pub maybe_a_str: Option<&'a str>,
pub maybe_a_string: Option<String>,
pub magic_number: i32,
pub low_quality_pi: f32,
pub high_quality_pi: f64,
pub maybe_pi: Option<f32>,
pub maybe_best_pi: Option<f64>,
pub borrowed_maybe_a_string: &'a Option<String>,
pub borrowed_maybe_a_str: &'a Option<&'a str>,
}
#[cfg(test)]
mod tests {
use super::*;
use parquet::{
file::{
properties::WriterProperties,
writer::{FileWriter, SerializedFileWriter},
},
schema::parser::parse_message_type,
};
use std::{env, fs, io::Write, sync::Arc};
#[test]
fn test_parquet_derive_hello() {
let file = get_temp_file("test_parquet_derive_hello", &[]);
let schema_str = "message schema {
REQUIRED boolean a_bool;
REQUIRED BINARY a_str (UTF8);
REQUIRED BINARY a_string (UTF8);
REQUIRED BINARY a_borrowed_string (UTF8);
OPTIONAL BINARY a_maybe_str (UTF8);
OPTIONAL BINARY a_maybe_string (UTF8);
REQUIRED INT32 magic_number;
REQUIRED FLOAT low_quality_pi;
REQUIRED DOUBLE high_quality_pi;
OPTIONAL FLOAT maybe_pi;
OPTIONAL DOUBLE maybe_best_pi;
OPTIONAL BINARY borrowed_maybe_a_string (UTF8);
OPTIONAL BINARY borrowed_maybe_a_str (UTF8);
}";
let schema = Arc::new(parse_message_type(schema_str).unwrap());
let props = Arc::new(WriterProperties::builder().build());
let mut writer = SerializedFileWriter::new(file, schema, props).unwrap();
let a_str = "hello mother".to_owned();
let a_borrowed_string = "cool news".to_owned();
let maybe_a_string = Some("it's true, I'm a string".to_owned());
let maybe_a_str = Some(&a_str[..]);
let drs: Vec<ACompleteRecord> = vec![ACompleteRecord {
a_bool: true,
a_str: &a_str[..],
a_string: "hello father".into(),
a_borrowed_string: &a_borrowed_string,
maybe_a_str: Some(&a_str[..]),
maybe_a_string: Some(a_str.clone()),
magic_number: 100,
low_quality_pi: 3.14,
high_quality_pi: 3.1415,
maybe_pi: Some(3.14),
maybe_best_pi: Some(3.1415),
borrowed_maybe_a_string: &maybe_a_string,
borrowed_maybe_a_str: &maybe_a_str,
}];
let mut row_group = writer.next_row_group().unwrap();
drs.as_slice().write_to_row_group(&mut row_group).unwrap();
writer.close_row_group(row_group).unwrap();
writer.close().unwrap();
}
/// Returns file handle for a temp file in 'target' directory with a provided content
pub fn get_temp_file(file_name: &str, content: &[u8]) -> fs::File {
// build tmp path to a file in "target/debug/testdata"
let mut path_buf = env::current_dir().unwrap();
path_buf.push("target");
path_buf.push("debug");
path_buf.push("testdata");
fs::create_dir_all(&path_buf).unwrap();
path_buf.push(file_name);
// write file content
let mut tmp_file = fs::File::create(path_buf.as_path()).unwrap();
tmp_file.write_all(content).unwrap();
tmp_file.sync_all().unwrap();
// return file handle for both read and write
let file = fs::OpenOptions::new()
.read(true)
.write(true)
.open(path_buf.as_path());
assert!(file.is_ok());
file.unwrap()
}
}