Skip to content

Commit

Permalink
ICU4X: Adding list format testing (unicode-org#229)
Browse files Browse the repository at this point in the history
* ICU4X: Adding list format testing

* cargo fmt on ICU4X source
  • Loading branch information
sven-oly authored May 20, 2024
1 parent 059575a commit bfed07f
Show file tree
Hide file tree
Showing 6 changed files with 115 additions and 7 deletions.
94 changes: 94 additions & 0 deletions executors/rust/1.3/src/listfmt.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
//! Executor provides tests for list formatting in locale-sensitive manner.
use serde::{Deserialize, Serialize};
use serde_json::{json, Value};

use icu::list::*;
use icu::locid::Locale;

use writeable::Writeable;

#[derive(Deserialize, Serialize, Debug)]
#[serde(rename_all = "snake_case")]
struct ListFormatOptions {
style: Option<String>,
list_type: Option<String>,
}

// Function runs list format tests
pub fn run_list_fmt_test(json_obj: &Value) -> Result<Value, String> {
let label = &json_obj["label"].as_str().unwrap();

let locale_str: &str = json_obj["locale"].as_str().unwrap();
let locale = locale_str.parse::<Locale>().unwrap();

let options = &json_obj["options"]; // This will be an array.
let option_struct: ListFormatOptions = serde_json::from_str(&options.to_string()).unwrap();

let style: &str = option_struct.style.as_ref().unwrap();
let list_type: &str = option_struct.list_type.as_ref().unwrap();

// get input list

// Style
let list_style: ListLength = if style == "long" {
ListLength::Wide
} else if style == "short" {
ListLength::Short
} else if style == "narrow" {
ListLength::Narrow
} else {
// Report an unsupported option.
return Ok(json!({
"label": label,
"error_detail": {"option": style},
"unsupported": "unknown list style",
"error_type": "unsupported",
}));
};

let list_formatter_result: Result<ListFormatter, ListError> = if list_type == "conjunction" {
// Reference: https://docs.rs/icu/latest/icu/list/index.html
ListFormatter::try_new_and_with_length(&locale.into(), list_style)
} else if list_type == "disjunction" {
ListFormatter::try_new_or_with_length(&locale.into(), list_style)
} else if list_type == "unit" {
ListFormatter::try_new_unit_with_length(&locale.into(), list_style)
} else {
// This option is not supported.
return Ok(json!({
"label": label,
"error_detail": {"option": list_type},
"unsupported": "unknown format type",
"error_type": "unsupported",
}));
};

// Data to be formatted.
let input_list = json_obj["input_list"].as_array().unwrap();
let input_list_str_iter = input_list
.iter()
.map(|json_value| json_value.as_str().unwrap());

let json_result = match list_formatter_result {
Ok(formatter) => {
json!({
"label": label,
"result": formatter.format(
input_list_str_iter).write_to_string().into_owned()
})
}
Err(e) => {
json!({
"label": label,
"locale_label": locale_str,
"error": e.to_string(),
"error_type": "unsupported",
"unsupported": e.to_string(),
"error_detail": {"unsupported_locale": locale_str}
})
}
};

Ok(json_result)
}
8 changes: 7 additions & 1 deletion executors/rust/1.3/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,11 +21,13 @@ mod decimalfmt;
mod displaynames;
mod langnames;
mod likelysubtags;
mod listfmt;
mod numberfmt;

use collator::run_collation_test;
use langnames::run_language_name_test;
use likelysubtags::run_likelysubtags_test;
use listfmt::run_list_fmt_test;
use numberfmt::run_numberformat_test;

use serde_json::{json, Value};
Expand Down Expand Up @@ -68,7 +70,9 @@ fn main() -> io::Result<()> {
"collation_short",
"number_fmt",
"decimal_fmt",
"likelysubtags"] }
"likelysubtags",
"list_fmt"
] }
);
println!("{}", json_result);
}
Expand Down Expand Up @@ -103,6 +107,8 @@ fn main() -> io::Result<()> {
run_language_name_test(&json_info)
} else if test_type == "likely_subtags" {
run_likelysubtags_test(&json_info)
} else if test_type == "list_fmt" {
run_list_fmt_test(&json_info)
} else {
Err(test_type.to_string())
};
Expand Down
4 changes: 2 additions & 2 deletions executors/test_strings.txt
Original file line number Diff line number Diff line change
Expand Up @@ -285,8 +285,8 @@

{"test_type": "list_fmt", "label":"en_-GB 2000", "input_string": "2000-01-01T21:00:00.000Z","input_list":[],"options":{"style":"long","type":"conjunction"},"locale":"en-GB"}

{"test_type": "list_fmt", "label":"12","input_list":["dog","cat"],"options":{"style":"narrow","type":"conjunction"},"locale":"en-GB"}
{"test_type": "list_fmt", "label":"12","input_list":["dog","cat","fish"],"options":{"style":"long","type":"conjunction"},"locale":"en-GB"}
{"test_type": "list_fmt", "label":"12","input_list":["dog","cat"],"options":{"style":"narrow","list_type":"conjunction", "type":"conjunction"},"locale":"en-GB"}
{"test_type": "list_fmt", "label":"12","input_list":["dog","cat","fish"],"options":{"style":"long","list_type":"conjunction"},"locale":"en-GB"}
{"test_type": "list_fmt", "label":"12","input_list":["dog","cat","fish"],"options":{"style":"long","type":"disjunction"},"locale":"en-GB"}
{"test_type": "list_fmt", "label":"12","input_list":["dog","cat","fish"],"options":{"style":"long","type":"unit"},"locale":"en-GB"}

Expand Down
8 changes: 5 additions & 3 deletions run_config.json
Original file line number Diff line number Diff line change
Expand Up @@ -230,7 +230,8 @@
"collation_short",
"number_fmt",
"lang_names",
"likely_subtags"
"likely_subtags",
"list_fmt"
],
"per_execution": 10000
}
Expand All @@ -246,9 +247,10 @@
"exec": "rust",
"test_type": [
"collation_short",
"number_fmt",
"lang_names",
"likely_subtags"
"list_fmt",
"likely_subtags",
"number_fmt"
],
"per_execution": 10000
}
Expand Down
5 changes: 5 additions & 0 deletions schema/list_fmt/test_schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,11 @@
"enum": ["long", "short", "narrow"]
},
"type": {
"description": "Deprecated! The kind of connection between list items, e.g., and/or/none",
"type": "string",
"enum": ["conjunction", "disjunction", "unit"]
},
"list_type": {
"description": "The kind of connection between list items, e.g., and/or/none",
"type": "string",
"enum": ["conjunction", "disjunction", "unit"]
Expand Down
3 changes: 2 additions & 1 deletion testgen/generators/list_fmt_gen.js
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,8 @@ function generateAll() {
// Create format object with these options
let all_options = {
'style': style,
'type': type
'list_type': type, // Needed because "type" is a reserved word in Rust
'type': type // Backward compatible
}

let formatter;
Expand Down

0 comments on commit bfed07f

Please sign in to comment.