xenadmin/XenAdminTests/I18nResourceFilesTests.cs
Alexander Schulz 2d1f47c321 Integrade changes from master-7.4 into master (https://github.com/xcp-ng/xenadmin/issues/68)
proper fix: use Path to TestDirectory

https://github.com/nunit/docs/wiki/Breaking-Changes

CurrentDirectory:
No longer set to the directory containing the test assembly. Use TestContext.CurrentContext.TestDirectory to locate that directory.
fix Test CertificateDialogTests

Path to the Cert was build as:
 xenadmin\TestResources\TestDevCertificate.cer

but should be:
 xenadmin\XenAdminTests\TestResources\TestDevCertificate.cer
fix Test TestFailingReaderGeneration

Ionic.BZip2 is throwing an IOException:
System.IO.IOException: 'Not a valid BZip2 stream. byte 0, expected '66', got '-1''
use update.xml in master brach on github (as a first solution)

https://github.com/xcp-ng/xenadmin/issues/29

Do not check for ContainerCapability on XCP-ng, just belive in it :-)

If server is in not licenced, don't show alert icon

Changed SetUp to OneTimeSetup in SetUpFixture

https://github.com/xcp-ng/xenadmin/issues/24

abort, if BUILD_NUMBER environment variable is not set

build automation

Ignore ".vs" folder
splash buildable with Visual Studio Community 2018

https://github.com/xcp-ng/xenadmin/issues/24 Get Tests running

https://github.com/xcp-ng/xenadmin/issues/24 Get Tests running

real world: edition "platinum" has changed to "desktop-plus"

https://github.com/xcp-ng/xenadmin/issues/24 Get Tests running

set culture to "en-EN" to ensure correct parsing

https://github.com/xcp-ng/xenadmin/issues/24 Get Tests running

correct adaption to nunit 3

adapt to nunit 3

adapt path

real world: edition "platinum" has changed to "desktop-plus"

Use Nunit and Moq from NuGet; Adapt tests to Nunit 3

https://github.com/xcp-ng/xenadmin/issues/24 Get Tests running

Fill AssemblyFileVersion

Idea from https://github.com/xcp-ng/xenadmin/issues/17 Show Version in Title

Tidy up Branding/Trademarks/License

https://github.com/xcp-ng/xenadmin/issues/18

Comment unreachable code to be buildable (https://github.com/xcp-ng/xenadmin/issues/14#issuecomment-380041068)

XCP-ng Console should connect to any flavor of XenServer

(cherry picked from commit 7e2342534d75193685139226fcaf89bb365fc706)
2019-02-09 00:43:14 +01:00

142 lines
5.1 KiB
C#

/* Copyright (c) Citrix Systems, Inc.
* All rights reserved.
*
* Redistribution and use in source and binary forms,
* with or without modification, are permitted provided
* that the following conditions are met:
*
* * Redistributions of source code must retain the above
* copyright notice, this list of conditions and the
* following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the
* following disclaimer in the documentation and/or other
* materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
* CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
using System.Globalization;
using System.Linq;
using System.Collections.Generic;
using System.Reflection;
using System.Text;
using NUnit.Framework;
namespace XenAdminTests
{
[TestFixture, Category(TestCategories.UICategoryA)]
public class ResourceFilesTests
{
/// <summary>
/// Assemblies to check
/// </summary>
private string[] m_assemblyIds = { "XenCenterMain", "XenModel", "XenOvf", "XenOvfTransport" };
/// <summary>
/// Available cultures (japanese and simplified chinese at the moment)
/// </summary>
private string[] m_locales = {"ja", "zh-CN"};
private string[] m_excludeFromCheck = {"XenAdmin.Help.HelpManager"};
/// <summary>
/// Test checks all resx files in the project have their i18n counterparts in place
/// </summary>
[Test]
public void TestEnsureI18nFilesInPlace()
{
var xenAdminTests = Assembly.GetExecutingAssembly();
var assemblies = GetAssembliesRecursively(xenAdminTests);
Assert.IsNotEmpty(assemblies, "Assemblies to check are found");
var missingSb = new StringBuilder();
var extraSb = new StringBuilder();
foreach (var assembly in assemblies)
{
List<string> defaultResx = new List<string>(assembly.GetManifestResourceNames().Where(resource => resource.EndsWith("resources")));
foreach (string locale in m_locales)
{
CultureInfo cultureInfo = new CultureInfo(locale);
Assembly localeDll = assembly.GetSatelliteAssembly(cultureInfo);
List<string> localeResx = new List<string>(localeDll.GetManifestResourceNames());
foreach (string def in defaultResx)
{
var name = def.Substring(0, def.Length - ".resources".Length);
var exclude = m_excludeFromCheck.Contains(name);
string localName = string.Format("{0}.{1}.resources", name, locale);
var localized = localeResx.Contains(localName);
if (localized && exclude)
extraSb.AppendLine(localName);
else if (!localized && !exclude)
missingSb.AppendLine(localName);
}
}
}
Assert.That(missingSb.ToString(), Is.Null.Or.Empty); //Missing resources detected.
Assert.That(extraSb.ToString(), Is.Null.Or.Empty); //"Unecessary resources detected"
}
#region Auxiliary private methods
/// <summary>
/// Some of the assemblies we need to check may not be in the manifest of the assembly we're
/// looking at, but are referenced by assemblies in the manifest. This method retrieves them.
/// </summary>
/// <param name="startAssembly"></param>
/// <returns></returns>
private List<Assembly> GetAssembliesRecursively(Assembly startAssembly)
{
var temp = new List<Assembly>();
AssemblyName[] assemblyNames = startAssembly.GetReferencedAssemblies();
var assemblyNamesToCheck = from name in assemblyNames
where m_assemblyIds.Contains(name.Name)
select name;
foreach (var assemblyName in assemblyNamesToCheck)
{
var assembly = Assembly.Load(assemblyName);
if (!temp.Contains(assembly))
{
temp.Add(assembly);
var secAssemblies = GetAssembliesRecursively(assembly);
foreach (var secAssembly in secAssemblies)
{
if (!temp.Contains(secAssembly))
temp.Add(secAssembly);
}
}
}
return temp;
}
#endregion
}
}