Unverified Commit c525988c authored by Shi-Hao Hong's avatar Shi-Hao Hong Committed by GitHub

Reorganize tests in l10n tool (#47704)

parent f65f7f01
...@@ -50,7 +50,7 @@ void main() { ...@@ -50,7 +50,7 @@ void main() {
); );
}); });
group('LocalizationsGenerator setters:', () { group('Setters', () {
test('happy path', () { test('happy path', () {
_standardFlutterDirectoryL10nSetup(fs); _standardFlutterDirectoryL10nSetup(fs);
expect(() { expect(() {
...@@ -174,7 +174,7 @@ void main() { ...@@ -174,7 +174,7 @@ void main() {
); );
}); });
group('className should only take valid Dart class names:', () { group('className should only take valid Dart class names', () {
LocalizationsGenerator generator; LocalizationsGenerator generator;
setUp(() { setUp(() {
_standardFlutterDirectoryL10nSetup(fs); _standardFlutterDirectoryL10nSetup(fs);
...@@ -242,7 +242,7 @@ void main() { ...@@ -242,7 +242,7 @@ void main() {
}); });
}); });
group('LocalizationsGenerator.parseArbFiles:', () { group('parseArbFiles', () {
test('correctly initializes supportedLocales and supportedLanguageCodes properties', () { test('correctly initializes supportedLocales and supportedLanguageCodes properties', () {
_standardFlutterDirectoryL10nSetup(fs); _standardFlutterDirectoryL10nSetup(fs);
...@@ -484,7 +484,7 @@ void main() { ...@@ -484,7 +484,7 @@ void main() {
expect(generator.supportedLocales.contains(LocaleInfo.fromString('zh')), true); expect(generator.supportedLocales.contains(LocaleInfo.fromString('zh')), true);
}); });
test('correctly parses @@locale property in arb file', () { test('correctly prioritizes @@locale property in arb file over filename', () {
const String arbFileWithEnLocale = '''{ const String arbFileWithEnLocale = '''{
"@@locale": "en", "@@locale": "en",
"title": "Stocks", "title": "Stocks",
...@@ -589,8 +589,8 @@ void main() { ...@@ -589,8 +589,8 @@ void main() {
}); });
}); });
group('LocalizationsGenerator.generateClassMethods:', () { group('generateClassMethods', () {
test('correctly generates a simple message with getter:', () { test('correctly generates a simple message with getter', () {
_standardFlutterDirectoryL10nSetup(fs); _standardFlutterDirectoryL10nSetup(fs);
final LocalizationsGenerator generator = LocalizationsGenerator(fs); final LocalizationsGenerator generator = LocalizationsGenerator(fs);
try { try {
...@@ -666,6 +666,7 @@ void main() { ...@@ -666,6 +666,7 @@ void main() {
'''); ''');
}); });
group('DateTime tests', () {
test('correctly generates simple message with dates', () { test('correctly generates simple message with dates', () {
const String singleDateMessageArbFileString = '''{ const String singleDateMessageArbFileString = '''{
"springBegins": "Spring begins on {springStartDate}", "springBegins": "Spring begins on {springStartDate}",
...@@ -897,19 +898,23 @@ void main() { ...@@ -897,19 +898,23 @@ void main() {
'''); ''');
}); });
test('correctly generates a plural message:', () { test('correctly generates a plural message with DateTime placeholders', () {
const String singlePluralMessageArbFileString = '''{ const String pluralMessageWithDateTimePlaceholder = '''{
"helloWorlds": "{count,plural, =0{Hello}=1{Hello World}=2{Hello two worlds}few{Hello {count} worlds}many{Hello all {count} worlds}other{Hello other {count} worlds}}", "helloWorlds": "{count,plural, =1{Hello World, today is {currentDate}}=2{Hello two worlds, today is {currentDate}}many{Hello all {count} worlds, today is {currentDate}}other{Hello other {count} worlds, today is {currentDate}}}",
"@helloWorlds": { "@helloWorlds": {
"placeholders": { "placeholders": {
"count": {} "count": {},
"currentDate": {
"type": "DateTime",
"format": "yMMMMEEEEd"
}
} }
} }
}'''; }''';
final Directory l10nDirectory = fs.currentDirectory.childDirectory('lib').childDirectory('l10n') final Directory l10nDirectory = fs.currentDirectory.childDirectory('lib').childDirectory('l10n')
..createSync(recursive: true); ..createSync(recursive: true);
l10nDirectory.childFile(defaultTemplateArbFileName) l10nDirectory.childFile(defaultTemplateArbFileName)
.writeAsStringSync(singlePluralMessageArbFileString); .writeAsStringSync(pluralMessageWithDateTimePlaceholder);
final LocalizationsGenerator generator = LocalizationsGenerator(fs); final LocalizationsGenerator generator = LocalizationsGenerator(fs);
try { try {
...@@ -928,25 +933,27 @@ void main() { ...@@ -928,25 +933,27 @@ void main() {
expect(generator.classMethods, isNotEmpty); expect(generator.classMethods, isNotEmpty);
expect( expect(
generator.classMethods.first, generator.classMethods.first,
''' String helloWorlds(int count) { ''' String helloWorlds(int count, Object currentDate) {
final DateFormat currentDateDateFormat = DateFormat.yMMMMEEEEd(_localeName);
final String currentDateString = currentDateDateFormat.format(currentDate);
return Intl.plural( return Intl.plural(
count, count,
locale: _localeName, locale: _localeName,
name: 'helloWorlds', name: 'helloWorlds',
args: <Object>[count], args: <Object>[count, currentDateString],
zero: 'Hello', one: 'Hello World, today is \$currentDateString',
one: 'Hello World', two: 'Hello two worlds, today is \$currentDateString',
two: 'Hello two worlds', many: 'Hello all \$count worlds, today is \$currentDateString',
few: 'Hello \$count worlds', other: 'Hello other \$count worlds, today is \$currentDateString'
many: 'Hello all \$count worlds',
other: 'Hello other \$count worlds'
); );
} }
''' '''
); );
}); });
});
group('Number tests', () {
test('correctly generates simple message with numbers', () { test('correctly generates simple message with numbers', () {
const String singleNumberMessage = '''{ const String singleNumberMessage = '''{
"courseCompletion": "You have completed {progress} of the course.", "courseCompletion": "You have completed {progress} of the course.",
...@@ -988,6 +995,62 @@ void main() { ...@@ -988,6 +995,62 @@ void main() {
); );
final String progressString = progressNumberFormat.format(progress); final String progressString = progressNumberFormat.format(progress);
return Intl.message(
r'You have completed \$progressString of the course.',
locale: _localeName,
name: 'courseCompletion',
desc: r'The amount of progress the student has made in their class.',
args: <Object>[progressString]
);
}
''');
});
test('correctly adds optional parameters to numbers', () {
const String singleNumberMessage = '''{
"courseCompletion": "You have completed {progress} of the course.",
"@courseCompletion": {
"description": "The amount of progress the student has made in their class.",
"placeholders": {
"progress": {
"type": "Number",
"format": "decimalPercentPattern",
"optionalParameters": {
"decimalDigits": 2
}
}
}
}
}''';
final Directory l10nDirectory = fs.currentDirectory.childDirectory('lib').childDirectory('l10n')
..createSync(recursive: true);
l10nDirectory.childFile(defaultTemplateArbFileName)
.writeAsStringSync(singleNumberMessage);
final LocalizationsGenerator generator = LocalizationsGenerator(fs);
try {
generator.initialize(
l10nDirectoryPath: defaultArbPathString,
templateArbFileName: defaultTemplateArbFileName,
outputFileString: defaultOutputFileString,
classNameString: defaultClassNameString,
);
generator.parseArbFiles();
generator.generateClassMethods();
} on Exception catch (e) {
fail('Parsing template arb file should succeed: \n$e');
}
expect(generator.classMethods, isNotEmpty);
expect(
generator.classMethods.first,
''' String courseCompletion(Object progress) {
final NumberFormat progressNumberFormat = NumberFormat.decimalPercentPattern(
locale: _localeName,
decimalDigits: 2,
);
final String progressString = progressNumberFormat.format(progress);
return Intl.message( return Intl.message(
r'You have completed \$progressString of the course.', r'You have completed \$progressString of the course.',
locale: _localeName, locale: _localeName,
...@@ -1036,8 +1099,59 @@ void main() { ...@@ -1036,8 +1099,59 @@ void main() {
fail('Improper date formatting should throw an exception'); fail('Improper date formatting should throw an exception');
}); });
});
group('plural messages', () {
test('correctly generates a plural message', () {
const String singlePluralMessageArbFileString = '''{
"helloWorlds": "{count,plural, =0{Hello}=1{Hello World}=2{Hello two worlds}few{Hello {count} worlds}many{Hello all {count} worlds}other{Hello other {count} worlds}}",
"@helloWorlds": {
"placeholders": {
"count": {}
}
}
}''';
final Directory l10nDirectory = fs.currentDirectory.childDirectory('lib').childDirectory('l10n')
..createSync(recursive: true);
l10nDirectory.childFile(defaultTemplateArbFileName)
.writeAsStringSync(singlePluralMessageArbFileString);
final LocalizationsGenerator generator = LocalizationsGenerator(fs);
try {
generator.initialize(
l10nDirectoryPath: defaultArbPathString,
templateArbFileName: defaultTemplateArbFileName,
outputFileString: defaultOutputFileString,
classNameString: defaultClassNameString,
);
generator.parseArbFiles();
generator.generateClassMethods();
} on Exception catch (e) {
fail('Parsing template arb file should succeed: \n$e');
}
expect(generator.classMethods, isNotEmpty);
expect(
generator.classMethods.first,
''' String helloWorlds(int count) {
return Intl.plural(
count,
locale: _localeName,
name: 'helloWorlds',
args: <Object>[count],
zero: 'Hello',
one: 'Hello World',
two: 'Hello two worlds',
few: 'Hello \$count worlds',
many: 'Hello all \$count worlds',
other: 'Hello other \$count worlds'
);
}
'''
);
});
test('correctly generates a plural message with placeholders:', () { test('correctly generates a plural message with placeholders', () {
const String pluralMessageWithMultiplePlaceholders = '''{ const String pluralMessageWithMultiplePlaceholders = '''{
"helloWorlds": "{count,plural, =0{Hello}=1{Hello {adjective} World}=2{Hello two {adjective} worlds}few{Hello {count} {adjective} worlds}many{Hello all {count} {adjective} worlds}other{Hello other {count} {adjective} worlds}}", "helloWorlds": "{count,plural, =0{Hello}=1{Hello {adjective} World}=2{Hello two {adjective} worlds}few{Hello {count} {adjective} worlds}many{Hello all {count} {adjective} worlds}other{Hello other {count} {adjective} worlds}}",
"@helloWorlds": { "@helloWorlds": {
...@@ -1087,7 +1201,7 @@ void main() { ...@@ -1087,7 +1201,7 @@ void main() {
); );
}); });
test('correctly generates a plural message with DateTime placeholders:', () { test('correctly generates a plural message with DateTime placeholders', () {
const String pluralMessageWithDateTimePlaceholder = '''{ const String pluralMessageWithDateTimePlaceholder = '''{
"helloWorlds": "{count,plural, =1{Hello World, today is {currentDate}}=2{Hello two worlds, today is {currentDate}}many{Hello all {count} worlds, today is {currentDate}}other{Hello other {count} worlds, today is {currentDate}}}", "helloWorlds": "{count,plural, =1{Hello World, today is {currentDate}}=2{Hello two worlds, today is {currentDate}}many{Hello all {count} worlds, today is {currentDate}}other{Hello other {count} worlds, today is {currentDate}}}",
"@helloWorlds": { "@helloWorlds": {
...@@ -1141,7 +1255,7 @@ void main() { ...@@ -1141,7 +1255,7 @@ void main() {
); );
}); });
test('correctly generates a plural message with number placeholders:', () { test('correctly generates a plural message with number placeholders', () {
const String pluralMessageWithDateTimePlaceholder = '''{ const String pluralMessageWithDateTimePlaceholder = '''{
"helloWorlds": "{count,plural, =1{Hello World of {population} citizens}=2{Hello two worlds with {population} total citizens}many{Hello all {count} worlds, with a total of {population} citizens}other{Hello other {count} worlds, with a total of {population} citizens}}", "helloWorlds": "{count,plural, =1{Hello World of {population} citizens}=2{Hello two worlds with {population} total citizens}many{Hello all {count} worlds, with a total of {population} citizens}other{Hello other {count} worlds, with a total of {population} citizens}}",
"@helloWorlds": { "@helloWorlds": {
...@@ -1197,63 +1311,7 @@ void main() { ...@@ -1197,63 +1311,7 @@ void main() {
); );
}); });
test('correctly adds optional parameters to numbers:', () { test('should throw attempting to generate a plural message without placeholders', () {
const String singleNumberMessage = '''{
"courseCompletion": "You have completed {progress} of the course.",
"@courseCompletion": {
"description": "The amount of progress the student has made in their class.",
"placeholders": {
"progress": {
"type": "Number",
"format": "decimalPercentPattern",
"optionalParameters": {
"decimalDigits": 2
}
}
}
}
}''';
final Directory l10nDirectory = fs.currentDirectory.childDirectory('lib').childDirectory('l10n')
..createSync(recursive: true);
l10nDirectory.childFile(defaultTemplateArbFileName)
.writeAsStringSync(singleNumberMessage);
final LocalizationsGenerator generator = LocalizationsGenerator(fs);
try {
generator.initialize(
l10nDirectoryPath: defaultArbPathString,
templateArbFileName: defaultTemplateArbFileName,
outputFileString: defaultOutputFileString,
classNameString: defaultClassNameString,
);
generator.parseArbFiles();
generator.generateClassMethods();
} on Exception catch (e) {
fail('Parsing template arb file should succeed: \n$e');
}
expect(generator.classMethods, isNotEmpty);
expect(
generator.classMethods.first,
''' String courseCompletion(Object progress) {
final NumberFormat progressNumberFormat = NumberFormat.decimalPercentPattern(
locale: _localeName,
decimalDigits: 2,
);
final String progressString = progressNumberFormat.format(progress);
return Intl.message(
r'You have completed \$progressString of the course.',
locale: _localeName,
name: 'courseCompletion',
desc: r'The amount of progress the student has made in their class.',
args: <Object>[progressString]
);
}
''');
});
test('should throw attempting to generate a plural message without placeholders:', () {
const String pluralMessageWithoutPlaceholdersAttribute = '''{ const String pluralMessageWithoutPlaceholdersAttribute = '''{
"helloWorlds": "{count,plural, =0{Hello}=1{Hello World}=2{Hello two worlds}few{Hello {count} worlds}many{Hello all {count} worlds}other{Hello other {count} worlds}}", "helloWorlds": "{count,plural, =0{Hello}=1{Hello World}=2{Hello two worlds}few{Hello {count} worlds}many{Hello all {count} worlds}other{Hello other {count} worlds}}",
"@helloWorlds": { "@helloWorlds": {
...@@ -1283,7 +1341,7 @@ void main() { ...@@ -1283,7 +1341,7 @@ void main() {
fail('Generating class methods without placeholders should not succeed'); fail('Generating class methods without placeholders should not succeed');
}); });
test('should throw attempting to generate a plural message with empty placeholders map:', () { test('should throw attempting to generate a plural message with an empty placeholders map', () {
const String pluralMessageWithEmptyPlaceholdersMap = '''{ const String pluralMessageWithEmptyPlaceholdersMap = '''{
"helloWorlds": "{count,plural, =0{Hello}=1{Hello World}=2{Hello two worlds}few{Hello {count} worlds}many{Hello all {count} worlds}other{Hello other {count} worlds}}", "helloWorlds": "{count,plural, =0{Hello}=1{Hello World}=2{Hello two worlds}few{Hello {count} worlds}many{Hello all {count} worlds}other{Hello other {count} worlds}}",
"@helloWorlds": { "@helloWorlds": {
...@@ -1314,7 +1372,7 @@ void main() { ...@@ -1314,7 +1372,7 @@ void main() {
fail('Generating class methods without placeholders should not succeed'); fail('Generating class methods without placeholders should not succeed');
}); });
test('should throw attempting to generate a plural message with no resource attributes:', () { test('should throw attempting to generate a plural message with no resource attributes', () {
const String pluralMessageWithoutResourceAttributes = '''{ const String pluralMessageWithoutResourceAttributes = '''{
"helloWorlds": "{count,plural, =0{Hello}=1{Hello World}=2{Hello two worlds}few{Hello {count} worlds}many{Hello all {count} worlds}other{Hello other {count} worlds}}" "helloWorlds": "{count,plural, =0{Hello}=1{Hello World}=2{Hello two worlds}few{Hello {count} worlds}many{Hello all {count} worlds}other{Hello other {count} worlds}}"
}'''; }''';
...@@ -1342,7 +1400,7 @@ void main() { ...@@ -1342,7 +1400,7 @@ void main() {
fail('Generating plural class method without resource attributes should not succeed'); fail('Generating plural class method without resource attributes should not succeed');
}); });
test('should throw attempting to generate a plural message with incorrect placeholders format:', () { test('should throw attempting to generate a plural message with incorrect format for placeholders', () {
const String pluralMessageWithIncorrectPlaceholderFormat = '''{ const String pluralMessageWithIncorrectPlaceholderFormat = '''{
"helloWorlds": "{count,plural, =0{Hello}=1{Hello World}=2{Hello two worlds}few{Hello {count} worlds}many{Hello all {count} worlds}other{Hello other {count} worlds}}", "helloWorlds": "{count,plural, =0{Hello}=1{Hello World}=2{Hello two worlds}few{Hello {count} worlds}many{Hello all {count} worlds}other{Hello other {count} worlds}}",
"@helloWorlds": { "@helloWorlds": {
...@@ -1372,8 +1430,9 @@ void main() { ...@@ -1372,8 +1430,9 @@ void main() {
} }
fail('Generating class methods with incorrect placeholder format should not succeed'); fail('Generating class methods with incorrect placeholder format should not succeed');
}); });
});
test('should throw when failing to parse the arb file:', () { test('should throw when failing to parse the arb file', () {
const String arbFileWithTrailingComma = '''{ const String arbFileWithTrailingComma = '''{
"title": "Stocks", "title": "Stocks",
"@title": { "@title": {
...@@ -1406,7 +1465,7 @@ void main() { ...@@ -1406,7 +1465,7 @@ void main() {
); );
}); });
test('should throw when resource is missing resource attribute:', () { test('should throw when resource is missing resource attribute', () {
const String arbFileWithMissingResourceAttribute = '''{ const String arbFileWithMissingResourceAttribute = '''{
"title": "Stocks" "title": "Stocks"
}'''; }''';
...@@ -1529,8 +1588,8 @@ void main() { ...@@ -1529,8 +1588,8 @@ void main() {
}); });
}); });
group('LocalizationsGenerator.generateOutputFile:', () { group('generateOutputFile', () {
test('correctly generates the localizations classes:', () { test('correctly generates the localizations classes', () {
_standardFlutterDirectoryL10nSetup(fs); _standardFlutterDirectoryL10nSetup(fs);
final LocalizationsGenerator generator = LocalizationsGenerator(fs); final LocalizationsGenerator generator = LocalizationsGenerator(fs);
try { try {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment