Free cookie consent management tool by TermsFeed Policy Generator

Ignore:
Timestamp:
01/28/19 17:39:41 (5 years ago)
Author:
gkronber
Message:

#2520: several fixes based on failing unit tests

  • adapted unit tests that check StorableConstructors
  • missing translations of StorableClass -> StorableType
  • missing StorableConstructors
  • missing or unecessary PluginDependencies / ProjectReferences
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/HeuristicLab.Tests/HeuristicLab-3.3/StorableTest.cs

    r16565 r16571  
    4242
    4343      foreach (Type storableType in ApplicationManager.Manager.GetTypes(typeof(object))
    44         .Where(StorableClassAttribute.IsStorableClass)) {
     44        .Where(StorableTypeAttribute.IsStorableType)) {
    4545        //test only types contained in HL plugin assemblies
     46        if (!storableType.Namespace.StartsWith("HeuristicLab")) continue;
    4647        if (storableType.Namespace.Contains(".Tests")) continue;
    4748        if (!PluginLoader.Assemblies.Contains(storableType.Assembly)) continue;
    4849
     50        if (storableType.IsEnum || storableType.IsInterface) continue;
     51        var storableFields = storableType
     52          .GetFields(BindingFlags.Instance | BindingFlags.NonPublic | BindingFlags.Public)
     53          .Where(fi => StorableAttribute.IsStorable(fi));
     54        var storableProps = storableType
     55          .GetProperties(BindingFlags.Instance | BindingFlags.NonPublic | BindingFlags.Public)
     56          .Where(fi => StorableAttribute.IsStorable(fi));
     57
     58        // a storable constructor should be given but is not absolutely required.
     59        // when there are no storable fields then a storable ctor has no real purpose.
     60        if (!storableFields.Any() && !storableProps.Any()) continue;
     61
    4962        IEnumerable<ConstructorInfo> ctors = storableType.GetConstructors(BindingFlags.Instance | BindingFlags.NonPublic | BindingFlags.Public);
    50         ConstructorInfo storableConstructor = ctors.Where(c => c.GetParameters().Count() == 1 && c.GetParameters().First().ParameterType == typeof(bool)).FirstOrDefault();
     63        ConstructorInfo storableConstructor = ctors.Where(c => c.GetParameters().Count() == 1 && c.GetParameters().First().ParameterType == typeof(HEAL.Attic.StorableConstructorFlag)).FirstOrDefault();
    5164        if (storableConstructor == null) errorMessage.Append(Environment.NewLine + storableType.ToString() + ": No storable constructor is defined.");
    5265        else {
     
    6982      foreach (var type in ApplicationManager.Manager.GetTypes(typeof(object), onlyInstantiable: false, includeGenericTypeDefinitions: true)
    7083        .Where(t => t.Namespace != null && !t.Namespace.Contains(".Tests"))
    71         .Where(t => !StorableClassAttribute.IsStorableClass(t))) {
     84        .Where(t => !StorableTypeAttribute.IsStorableType(t))) {
    7285        var members = type.GetMembers(BindingFlags.Instance | BindingFlags.NonPublic | BindingFlags.Public | BindingFlags.DeclaredOnly);
    7386        var storableConstructor = members.SingleOrDefault(m => Attribute.IsDefined(m, typeof(StorableConstructorAttribute), inherit: false));
     
    7588
    7689        if (storableConstructor != null) {
    77           errorMessage.Append(Environment.NewLine + type.Namespace + "." + type.GetPrettyName() + ": Contains a storable constructor but is not a storable class.");
     90          errorMessage.Append(Environment.NewLine + type.Namespace + "." + type.GetPrettyName() + ": Contains a storable constructor but is not a storable type.");
    7891        } else if (storableMembers.Any()) {
    79           errorMessage.Append(Environment.NewLine + type.Namespace + "." + type.GetPrettyName() + ": Contains at least one storable member but is not a storable class.");
     92          errorMessage.Append(Environment.NewLine + type.Namespace + "." + type.GetPrettyName() + ": Contains at least one storable member but is not a storable type.");
    8093        }
    8194      }
Note: See TracChangeset for help on using the changeset viewer.