Free cookie consent management tool by TermsFeed Policy Generator

Ignore:
Timestamp:
07/07/19 23:40:10 (5 years ago)
Author:
mkommend
Message:

#2520: Merged 16565 - 16579 into stable.

Location:
stable
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • stable

  • stable/HeuristicLab.Tests

  • stable/HeuristicLab.Tests/HeuristicLab-3.3/StorableTest.cs

    r15584 r17097  
    11#region License Information
    22/* HeuristicLab
    3  * Copyright (C) 2002-2018 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
     3 * Copyright (C) 2002-2019 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
    44 *
    55 * This file is part of HeuristicLab.
     
    2525using System.Reflection;
    2626using System.Text;
     27using HEAL.Attic;
    2728using HeuristicLab.Common;
    2829using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
     
    4142
    4243      foreach (Type storableType in ApplicationManager.Manager.GetTypes(typeof(object))
    43         .Where(StorableClassAttribute.IsStorableClass)) {
     44        .Where(StorableTypeAttribute.IsStorableType)) {
    4445        //test only types contained in HL plugin assemblies
     46        if (!storableType.Namespace.StartsWith("HeuristicLab")) continue;
    4547        if (storableType.Namespace.Contains(".Tests")) continue;
    4648        if (!PluginLoader.Assemblies.Contains(storableType.Assembly)) continue;
    4749
     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
    4862        IEnumerable<ConstructorInfo> ctors = storableType.GetConstructors(BindingFlags.Instance | BindingFlags.NonPublic | BindingFlags.Public);
    49         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();
    5064        if (storableConstructor == null) errorMessage.Append(Environment.NewLine + storableType.ToString() + ": No storable constructor is defined.");
    5165        else {
     
    6882      foreach (var type in ApplicationManager.Manager.GetTypes(typeof(object), onlyInstantiable: false, includeGenericTypeDefinitions: true)
    6983        .Where(t => t.Namespace != null && !t.Namespace.Contains(".Tests"))
    70         .Where(t => !StorableClassAttribute.IsStorableClass(t))) {
     84        .Where(t => !StorableTypeAttribute.IsStorableType(t))) {
    7185        var members = type.GetMembers(BindingFlags.Instance | BindingFlags.NonPublic | BindingFlags.Public | BindingFlags.DeclaredOnly);
    7286        var storableConstructor = members.SingleOrDefault(m => Attribute.IsDefined(m, typeof(StorableConstructorAttribute), inherit: false));
     
    7488
    7589        if (storableConstructor != null) {
    76           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.");
    7791        } else if (storableMembers.Any()) {
    78           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.");
    7993        }
    8094      }
Note: See TracChangeset for help on using the changeset viewer.