SEBWIN-219: Made XML for localization more readable.

This commit is contained in:
dbuechel 2018-01-19 10:11:13 +01:00
parent 57c3afdaa5
commit 80be746860
4 changed files with 164 additions and 47 deletions

View file

@ -1,5 +1,9 @@
<?xml version="1.0" encoding="utf-8" ?> <?xml version="1.0" encoding="utf-8" ?>
<Text> <Text>
<LogWindow_Title>Application Log</LogWindow_Title> <Entry key="LogWindow_Title">Application Log</Entry>
<Version>Version</Version> <Entry key="Version">Version</Entry>
<Entry key="Notification_AboutTooltip">
Hello world
</Entry>
<Entry key="Notification_LogTooltip"></Entry>
</Text> </Text>

View file

@ -29,7 +29,7 @@ namespace SafeExamBrowser.Core.UnitTests.I18n
var text = sut.LoadText(); var text = sut.LoadText();
Assert.IsNotNull(text); Assert.IsNotNull(text);
Assert.IsTrue(text.Count == 2); Assert.IsTrue(text.Count == 4);
Assert.AreEqual("Application Log", text[TextKey.LogWindow_Title]); Assert.AreEqual("Application Log", text[TextKey.LogWindow_Title]);
Assert.AreEqual("Version", text[TextKey.Version]); Assert.AreEqual("Version", text[TextKey.Version]);
} }
@ -58,6 +58,19 @@ namespace SafeExamBrowser.Core.UnitTests.I18n
Assert.IsTrue(text.Count == 0); Assert.IsTrue(text.Count == 0);
} }
[TestMethod]
public void MustNeverSetNullValue()
{
var location = Assembly.GetAssembly(typeof(XmlTextResourceTests)).Location;
var path = Path.GetDirectoryName(location) + $@"\{nameof(I18n)}\Text_Valid.xml";
var sut = new XmlTextResource(path);
var text = sut.LoadText();
Assert.IsNotNull(text);
Assert.AreEqual(string.Empty, text[TextKey.Notification_LogTooltip]);
}
[TestMethod] [TestMethod]
[ExpectedException(typeof(ArgumentException))] [ExpectedException(typeof(ArgumentException))]
public void MustNotAcceptInvalidPath() public void MustNotAcceptInvalidPath()
@ -71,5 +84,18 @@ namespace SafeExamBrowser.Core.UnitTests.I18n
{ {
new XmlTextResource(null); new XmlTextResource(null);
} }
[TestMethod]
public void MustTrimValues()
{
var location = Assembly.GetAssembly(typeof(XmlTextResourceTests)).Location;
var path = Path.GetDirectoryName(location) + $@"\{nameof(I18n)}\Text_Valid.xml";
var sut = new XmlTextResource(path);
var text = sut.LoadText();
Assert.IsNotNull(text);
Assert.AreEqual("Hello world", text[TextKey.Notification_AboutTooltip]);
}
} }
} }

View file

@ -1,45 +1,129 @@
<?xml version="1.0" encoding="utf-8" ?> <?xml version="1.0" encoding="utf-8" ?>
<Text> <Text>
<Browser_ShowDeveloperConsole>Open Console</Browser_ShowDeveloperConsole> <Entry key="Browser_ShowDeveloperConsole">
<LogWindow_Title>Application Log</LogWindow_Title> Open Console
<MessageBox_ConfigureClientSuccess>The client configuration has been saved and will be used when you start the application the next time. Do you want to quit for now?</MessageBox_ConfigureClientSuccess> </Entry>
<MessageBox_ConfigureClientSuccessTitle>Configuration Successful</MessageBox_ConfigureClientSuccessTitle> <Entry key="LogWindow_Title">
<MessageBox_ShutdownError>An unexpected error occurred during the shutdown procedure! Please consult the application log for more information...</MessageBox_ShutdownError> Application Log
<MessageBox_ShutdownErrorTitle>Shutdown Error</MessageBox_ShutdownErrorTitle> </Entry>
<MessageBox_StartupError>An unexpected error occurred during the startup procedure! Please consult the application log for more information...</MessageBox_StartupError> <Entry key="MessageBox_ConfigureClientSuccess">
<MessageBox_StartupErrorTitle>Startup Error</MessageBox_StartupErrorTitle> The client configuration has been saved and will be used when you start the application the next time. Do you want to quit for now?
<Notification_AboutTooltip>About Safe Exam Browser</Notification_AboutTooltip> </Entry>
<Notification_LogTooltip>Application Log</Notification_LogTooltip> <Entry key="MessageBox_ConfigureClientSuccessTitle">
<SplashScreen_EmptyClipboard>Emptying clipboard</SplashScreen_EmptyClipboard> Configuration Successful
<SplashScreen_InitializeBrowser>Initializing browser</SplashScreen_InitializeBrowser> </Entry>
<SplashScreen_InitializeConfiguration>Initializing application configuration</SplashScreen_InitializeConfiguration> <Entry key="MessageBox_ShutdownError">
<SplashScreen_InitializeProcessMonitoring>Initializing process monitoring</SplashScreen_InitializeProcessMonitoring> An unexpected error occurred during the shutdown procedure! Please consult the application log for more information...
<SplashScreen_InitializeTaskbar>Initializing taskbar</SplashScreen_InitializeTaskbar> </Entry>
<SplashScreen_InitializeWindowMonitoring>Initializing window monitoring</SplashScreen_InitializeWindowMonitoring> <Entry key="MessageBox_ShutdownErrorTitle">
<SplashScreen_InitializeWorkingArea>Initializing working area</SplashScreen_InitializeWorkingArea> Shutdown Error
<SplashScreen_RestoreWorkingArea>Restoring working area</SplashScreen_RestoreWorkingArea> </Entry>
<SplashScreen_ShutdownProcedure>Initiating shutdown procedure</SplashScreen_ShutdownProcedure> <Entry key="MessageBox_StartupError">
<SplashScreen_StartEventHandling>Starting event handling</SplashScreen_StartEventHandling> An unexpected error occurred during the startup procedure! Please consult the application log for more information...
<SplashScreen_StartKeyboardInterception>Starting keyboard interception</SplashScreen_StartKeyboardInterception> </Entry>
<SplashScreen_StartMouseInterception>Starting mouse interception</SplashScreen_StartMouseInterception> <Entry key="MessageBox_StartupErrorTitle">
<SplashScreen_StartupProcedure>Initiating startup procedure</SplashScreen_StartupProcedure> Startup Error
<SplashScreen_StopEventHandling>Stopping event handling</SplashScreen_StopEventHandling> </Entry>
<SplashScreen_StopKeyboardInterception>Stopping keyboard interception</SplashScreen_StopKeyboardInterception> <Entry key="Notification_AboutTooltip">
<SplashScreen_StopMouseInterception>Stopping mouse interception</SplashScreen_StopMouseInterception> About Safe Exam Browser
<SplashScreen_StopProcessMonitoring>Stopping process monitoring</SplashScreen_StopProcessMonitoring> </Entry>
<SplashScreen_StopWindowMonitoring>Stopping window monitoring</SplashScreen_StopWindowMonitoring> <Entry key="Notification_LogTooltip">
<SplashScreen_TerminateBrowser>Terminating browser</SplashScreen_TerminateBrowser> Application Log
<SplashScreen_TerminateTaskbar>Terminating taskbar</SplashScreen_TerminateTaskbar> </Entry>
<SplashScreen_WaitExplorerStartup>Waiting for Windows explorer to start up</SplashScreen_WaitExplorerStartup> <Entry key="SplashScreen_EmptyClipboard">
<SplashScreen_WaitExplorerTermination>Waiting for Windows explorer to shut down</SplashScreen_WaitExplorerTermination> Emptying clipboard
<SystemControl_BatteryCharging>Plugged in, charging... (%%CHARGE%%%)</SystemControl_BatteryCharging> </Entry>
<SystemControl_BatteryCharged>Fully charged (%%CHARGE%%%)</SystemControl_BatteryCharged> <Entry key="SplashScreen_InitializeBrowser">
<SystemControl_BatteryChargeCriticalWarning>The battery charge is critically low. Please connect your computer to a power supply!</SystemControl_BatteryChargeCriticalWarning> Initializing browser
<SystemControl_BatteryChargeLowInfo>The battery charge is getting low. Consider connecting your computer to a power supply in time...</SystemControl_BatteryChargeLowInfo> </Entry>
<SystemControl_BatteryRemainingCharge>%%HOURS%%h %%MINUTES%%min remaining (%%CHARGE%%%)</SystemControl_BatteryRemainingCharge> <Entry key="SplashScreen_InitializeConfiguration">
<SystemControl_KeyboardLayoutTooltip>Click to choose a different keyboard layout...</SystemControl_KeyboardLayoutTooltip> Initializing application configuration
<SystemControl_WirelessConnected>Connected to '%%NAME%%'</SystemControl_WirelessConnected> </Entry>
<SystemControl_WirelessDisconnected>Disconnected</SystemControl_WirelessDisconnected> <Entry key="SplashScreen_InitializeProcessMonitoring">
<SystemControl_WirelessNotAvailable>No wireless network adapter available or turned on</SystemControl_WirelessNotAvailable> Initializing process monitoring
<Version>Version</Version> </Entry>
<Entry key="SplashScreen_InitializeTaskbar">
Initializing taskbar
</Entry>
<Entry key="SplashScreen_InitializeWindowMonitoring">
Initializing window monitoring
</Entry>
<Entry key="SplashScreen_InitializeWorkingArea">
Initializing working area
</Entry>
<Entry key="SplashScreen_RestoreWorkingArea">
Restoring working area
</Entry>
<Entry key="SplashScreen_ShutdownProcedure">
Initiating shutdown procedure
</Entry>
<Entry key="SplashScreen_StartEventHandling">
Starting event handling
</Entry>
<Entry key="SplashScreen_StartKeyboardInterception">
Starting keyboard interception
</Entry>
<Entry key="SplashScreen_StartMouseInterception">
Starting mouse interception
</Entry>
<Entry key="SplashScreen_StartupProcedure">
Initiating startup procedure
</Entry>
<Entry key="SplashScreen_StopEventHandling">
Stopping event handling
</Entry>
<Entry key="SplashScreen_StopKeyboardInterception">
Stopping keyboard interception
</Entry>
<Entry key="SplashScreen_StopMouseInterception">
Stopping mouse interception
</Entry>
<Entry key="SplashScreen_StopProcessMonitoring">
Stopping process monitoring
</Entry>
<Entry key="SplashScreen_StopWindowMonitoring">
Stopping window monitoring
</Entry>
<Entry key="SplashScreen_TerminateBrowser">
Terminating browser
</Entry>
<Entry key="SplashScreen_TerminateTaskbar">
Terminating taskbar
</Entry>
<Entry key="SplashScreen_WaitExplorerStartup">
Waiting for Windows explorer to start up
</Entry>
<Entry key="SplashScreen_WaitExplorerTermination">
Waiting for Windows explorer to shut down
</Entry>
<Entry key="SystemControl_BatteryCharging">
Plugged in, charging... (%%CHARGE%%%)
</Entry>
<Entry key="SystemControl_BatteryCharged">
Fully charged (%%CHARGE%%%)
</Entry>
<Entry key="SystemControl_BatteryChargeCriticalWarning">
The battery charge is critically low. Please connect your computer to a power supply!
</Entry>
<Entry key="SystemControl_BatteryChargeLowInfo">
The battery charge is getting low. Consider connecting your computer to a power supply in time...
</Entry>
<Entry key="SystemControl_BatteryRemainingCharge">
%%HOURS%%h %%MINUTES%%min remaining (%%CHARGE%%%)
</Entry>
<Entry key="SystemControl_KeyboardLayoutTooltip">
Click to choose a different keyboard layout...
</Entry>
<Entry key="SystemControl_WirelessConnected">
Connected to '%%NAME%%'
</Entry>
<Entry key="SystemControl_WirelessDisconnected">
Disconnected
</Entry>
<Entry key="SystemControl_WirelessNotAvailable">
No wireless network adapter available or turned on
</Entry>
<Entry key="Version">
Version
</Entry>
</Text> </Text>

View file

@ -45,9 +45,12 @@ namespace SafeExamBrowser.Core.I18n
foreach (var definition in xml.Root.Descendants()) foreach (var definition in xml.Root.Descendants())
{ {
if (Enum.TryParse(definition.Name.LocalName, out TextKey key)) var isEntry = definition.Name.LocalName == "Entry";
var hasValidKey = Enum.TryParse(definition.Attribute("key")?.Value, out TextKey key);
if (isEntry && hasValidKey)
{ {
text[key] = definition.Value; text[key] = definition.Value?.Trim() ?? string.Empty;
} }
} }