2021-02-04 19:15:23 +01:00
|
|
|
import React from 'react';
|
2023-01-17 16:51:35 +01:00
|
|
|
import { renderWithProvider } from '../../../test/lib/render-helpers';
|
2021-02-04 19:15:23 +01:00
|
|
|
import { getMessage } from './i18n-helper';
|
2020-03-11 16:00:05 +01:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
describe('i18n helper', () => {
|
2021-02-04 19:15:23 +01:00
|
|
|
const TEST_LOCALE_CODE = 'TEST_LOCALE_CODE';
|
2020-03-11 16:00:05 +01:00
|
|
|
|
2021-02-04 19:15:23 +01:00
|
|
|
const TEST_KEY_1 = 'TEST_KEY_1';
|
|
|
|
const TEST_KEY_2 = 'TEST_KEY_2';
|
|
|
|
const TEST_KEY_3 = 'TEST_KEY_3';
|
|
|
|
const TEST_KEY_4 = 'TEST_KEY_4';
|
|
|
|
const TEST_KEY_5 = 'TEST_KEY_5';
|
|
|
|
const TEST_KEY_6 = 'TEST_KEY_6';
|
|
|
|
const TEST_KEY_6_HELPER = 'TEST_KEY_6_HELPER';
|
|
|
|
const TEST_KEY_7 = 'TEST_KEY_7';
|
|
|
|
const TEST_KEY_7_HELPER_1 = 'TEST_KEY_7_HELPER_1';
|
|
|
|
const TEST_KEY_7_HELPER_2 = 'TEST_KEY_7_HELPER_2';
|
|
|
|
const TEST_KEY_8 = 'TEST_KEY_8';
|
|
|
|
const TEST_KEY_8_HELPER_1 = 'TEST_KEY_8_HELPER_1';
|
|
|
|
const TEST_KEY_8_HELPER_2 = 'TEST_KEY_8_HELPER_2';
|
2020-03-11 16:00:05 +01:00
|
|
|
|
2021-02-04 19:15:23 +01:00
|
|
|
const TEST_SUBSTITUTION_1 = 'TEST_SUBSTITUTION_1';
|
|
|
|
const TEST_SUBSTITUTION_2 = 'TEST_SUBSTITUTION_2';
|
|
|
|
const TEST_SUBSTITUTION_3 = 'TEST_SUBSTITUTION_3';
|
|
|
|
const TEST_SUBSTITUTION_4 = 'TEST_SUBSTITUTION_4';
|
|
|
|
const TEST_SUBSTITUTION_5 = 'TEST_SUBSTITUTION_5';
|
2020-03-11 16:00:05 +01:00
|
|
|
|
|
|
|
const testLocaleMessages = {
|
|
|
|
[TEST_KEY_1]: {
|
|
|
|
message: 'This is a simple message.',
|
|
|
|
expectedResult: 'This is a simple message.',
|
|
|
|
},
|
|
|
|
[TEST_KEY_2]: {
|
|
|
|
message: 'This is a message with a single non-react substitution $1.',
|
|
|
|
},
|
|
|
|
[TEST_KEY_3]: {
|
|
|
|
message: 'This is a message with two non-react substitutions $1 and $2.',
|
|
|
|
},
|
|
|
|
[TEST_KEY_4]: {
|
|
|
|
message: '$1 - $2 - $3 - $4 - $5',
|
|
|
|
},
|
|
|
|
[TEST_KEY_5]: {
|
|
|
|
message: '$1 - $2 - $3',
|
|
|
|
},
|
|
|
|
[TEST_KEY_6]: {
|
2020-11-03 00:41:28 +01:00
|
|
|
message: 'Testing a react substitution $1.',
|
2020-03-11 16:00:05 +01:00
|
|
|
},
|
|
|
|
[TEST_KEY_6_HELPER]: {
|
2020-11-03 00:41:28 +01:00
|
|
|
message: TEST_SUBSTITUTION_1,
|
2020-03-11 16:00:05 +01:00
|
|
|
},
|
|
|
|
[TEST_KEY_7]: {
|
2020-11-03 00:41:28 +01:00
|
|
|
message: 'Testing a react substitution $1 and another $2.',
|
2020-03-11 16:00:05 +01:00
|
|
|
},
|
|
|
|
[TEST_KEY_7_HELPER_1]: {
|
2020-11-03 00:41:28 +01:00
|
|
|
message: TEST_SUBSTITUTION_1,
|
2020-03-11 16:00:05 +01:00
|
|
|
},
|
|
|
|
[TEST_KEY_7_HELPER_2]: {
|
2020-11-03 00:41:28 +01:00
|
|
|
message: TEST_SUBSTITUTION_2,
|
2020-03-11 16:00:05 +01:00
|
|
|
},
|
|
|
|
[TEST_KEY_8]: {
|
2020-11-03 00:41:28 +01:00
|
|
|
message:
|
|
|
|
'Testing a mix $1 of react substitutions $2 and string substitutions $3 + $4.',
|
2020-03-11 16:00:05 +01:00
|
|
|
},
|
|
|
|
[TEST_KEY_8_HELPER_1]: {
|
2020-11-03 00:41:28 +01:00
|
|
|
message: TEST_SUBSTITUTION_3,
|
2020-03-11 16:00:05 +01:00
|
|
|
},
|
|
|
|
[TEST_KEY_8_HELPER_2]: {
|
2020-11-03 00:41:28 +01:00
|
|
|
message: TEST_SUBSTITUTION_4,
|
2020-03-11 16:00:05 +01:00
|
|
|
},
|
2021-02-04 19:15:23 +01:00
|
|
|
};
|
|
|
|
const t = getMessage.bind(null, TEST_LOCALE_CODE, testLocaleMessages);
|
2020-03-11 16:00:05 +01:00
|
|
|
|
|
|
|
const TEST_SUBSTITUTION_6 = (
|
2020-11-03 00:41:28 +01:00
|
|
|
<div style={{ color: 'red' }} key="test-react-substitutions-1">
|
|
|
|
{t(TEST_KEY_6_HELPER)}
|
2020-03-11 16:00:05 +01:00
|
|
|
</div>
|
2021-02-04 19:15:23 +01:00
|
|
|
);
|
2020-03-11 16:00:05 +01:00
|
|
|
const TEST_SUBSTITUTION_7_1 = (
|
2023-01-17 16:51:35 +01:00
|
|
|
<div style={{ color: 'red' }} key="test-react-substitutions-7-1">
|
2020-11-03 00:41:28 +01:00
|
|
|
{t(TEST_KEY_7_HELPER_1)}
|
2020-03-11 16:00:05 +01:00
|
|
|
</div>
|
2021-02-04 19:15:23 +01:00
|
|
|
);
|
2020-03-11 16:00:05 +01:00
|
|
|
const TEST_SUBSTITUTION_7_2 = (
|
2023-01-17 16:51:35 +01:00
|
|
|
<div style={{ color: 'blue' }} key="test-react-substitutions-7-2">
|
2020-11-03 00:41:28 +01:00
|
|
|
{t(TEST_KEY_7_HELPER_2)}
|
2020-03-11 16:00:05 +01:00
|
|
|
</div>
|
2021-02-04 19:15:23 +01:00
|
|
|
);
|
2020-03-11 16:00:05 +01:00
|
|
|
const TEST_SUBSTITUTION_8_1 = (
|
2023-01-17 16:51:35 +01:00
|
|
|
<div style={{ color: 'orange' }} key="test-react-substitutions-8-1">
|
2020-11-03 00:41:28 +01:00
|
|
|
{t(TEST_KEY_8_HELPER_1)}
|
2020-03-11 16:00:05 +01:00
|
|
|
</div>
|
2021-02-04 19:15:23 +01:00
|
|
|
);
|
2020-03-11 16:00:05 +01:00
|
|
|
const TEST_SUBSTITUTION_8_2 = (
|
2020-11-03 00:41:28 +01:00
|
|
|
<div style={{ color: 'pink' }} key="test-react-substitutions-1">
|
|
|
|
{t(TEST_KEY_8_HELPER_2)}
|
2020-03-11 16:00:05 +01:00
|
|
|
</div>
|
2021-02-04 19:15:23 +01:00
|
|
|
);
|
2020-03-11 16:00:05 +01:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
describe('getMessage', () => {
|
|
|
|
it('should return the exact message paired with key if there are no substitutions', () => {
|
2021-02-04 19:15:23 +01:00
|
|
|
const result = t(TEST_KEY_1);
|
2021-04-15 20:01:46 +02:00
|
|
|
expect(result).toStrictEqual('This is a simple message.');
|
2021-02-04 19:15:23 +01:00
|
|
|
});
|
2020-03-11 16:00:05 +01:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
it('should return the correct message when a single non-react substitution is made', () => {
|
2021-02-04 19:15:23 +01:00
|
|
|
const result = t(TEST_KEY_2, [TEST_SUBSTITUTION_1]);
|
2021-04-15 20:01:46 +02:00
|
|
|
expect(result).toStrictEqual(
|
2020-11-03 00:41:28 +01:00
|
|
|
`This is a message with a single non-react substitution ${TEST_SUBSTITUTION_1}.`,
|
2021-02-04 19:15:23 +01:00
|
|
|
);
|
|
|
|
});
|
2020-03-11 16:00:05 +01:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
it('should return the correct message when two non-react substitutions are made', () => {
|
2021-02-04 19:15:23 +01:00
|
|
|
const result = t(TEST_KEY_3, [TEST_SUBSTITUTION_1, TEST_SUBSTITUTION_2]);
|
2021-04-15 20:01:46 +02:00
|
|
|
expect(result).toStrictEqual(
|
2020-11-03 00:41:28 +01:00
|
|
|
`This is a message with two non-react substitutions ${TEST_SUBSTITUTION_1} and ${TEST_SUBSTITUTION_2}.`,
|
2021-02-04 19:15:23 +01:00
|
|
|
);
|
|
|
|
});
|
2020-03-11 16:00:05 +01:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
it('should return the correct message when multiple non-react substitutions are made', () => {
|
2020-11-03 00:41:28 +01:00
|
|
|
const result = t(TEST_KEY_4, [
|
|
|
|
TEST_SUBSTITUTION_1,
|
|
|
|
TEST_SUBSTITUTION_2,
|
|
|
|
TEST_SUBSTITUTION_3,
|
|
|
|
TEST_SUBSTITUTION_4,
|
|
|
|
TEST_SUBSTITUTION_5,
|
2021-02-04 19:15:23 +01:00
|
|
|
]);
|
2021-04-15 20:01:46 +02:00
|
|
|
expect(result).toStrictEqual(
|
2020-11-03 00:41:28 +01:00
|
|
|
`${TEST_SUBSTITUTION_1} - ${TEST_SUBSTITUTION_2} - ${TEST_SUBSTITUTION_3} - ${TEST_SUBSTITUTION_4} - ${TEST_SUBSTITUTION_5}`,
|
2021-02-04 19:15:23 +01:00
|
|
|
);
|
|
|
|
});
|
2020-03-11 16:00:05 +01:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
it('should correctly render falsey substitutions', () => {
|
2021-02-04 19:15:23 +01:00
|
|
|
const result = t(TEST_KEY_4, [0, -0, '', false, NaN]);
|
2021-04-15 20:01:46 +02:00
|
|
|
expect(result).toStrictEqual('0 - 0 - - false - NaN');
|
2021-02-04 19:15:23 +01:00
|
|
|
});
|
2020-07-03 18:02:35 +02:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
it('should render nothing for "null" and "undefined" substitutions', () => {
|
2021-02-04 19:15:23 +01:00
|
|
|
const result = t(TEST_KEY_5, [null, TEST_SUBSTITUTION_2]);
|
2021-04-15 20:01:46 +02:00
|
|
|
expect(result).toStrictEqual(` - ${TEST_SUBSTITUTION_2} - `);
|
2021-02-04 19:15:23 +01:00
|
|
|
});
|
2020-03-11 16:00:05 +01:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
it('should return the correct message when a single react substitution is made', () => {
|
2021-02-04 19:15:23 +01:00
|
|
|
const result = t(TEST_KEY_6, [TEST_SUBSTITUTION_6]);
|
2023-01-17 16:51:35 +01:00
|
|
|
|
|
|
|
const { container } = renderWithProvider(result);
|
|
|
|
|
|
|
|
expect(container).toMatchSnapshot();
|
2021-02-04 19:15:23 +01:00
|
|
|
});
|
2020-03-11 16:00:05 +01:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
it('should return the correct message when two react substitutions are made', () => {
|
2020-11-03 00:41:28 +01:00
|
|
|
const result = t(TEST_KEY_7, [
|
|
|
|
TEST_SUBSTITUTION_7_1,
|
|
|
|
TEST_SUBSTITUTION_7_2,
|
2021-02-04 19:15:23 +01:00
|
|
|
]);
|
2023-01-17 16:51:35 +01:00
|
|
|
|
|
|
|
const { container } = renderWithProvider(result);
|
|
|
|
|
|
|
|
expect(container).toMatchSnapshot();
|
2021-02-04 19:15:23 +01:00
|
|
|
});
|
2020-03-11 16:00:05 +01:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
it('should return the correct message when substituting a mix of react elements and strings', () => {
|
2020-11-03 00:41:28 +01:00
|
|
|
const result = t(TEST_KEY_8, [
|
|
|
|
TEST_SUBSTITUTION_1,
|
|
|
|
TEST_SUBSTITUTION_8_1,
|
|
|
|
TEST_SUBSTITUTION_2,
|
|
|
|
TEST_SUBSTITUTION_8_2,
|
2021-02-04 19:15:23 +01:00
|
|
|
]);
|
2023-01-17 16:51:35 +01:00
|
|
|
|
|
|
|
const { container } = renderWithProvider(result);
|
|
|
|
|
|
|
|
expect(container).toMatchSnapshot();
|
2021-02-04 19:15:23 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|