nunit-core team mailing list archive
-
nunit-core team
-
Mailing list archive
-
Message #02375
[Bug 901192] Re: Feature request: Provide a strongly typed variant of the Property constraint
This is a good idea but requires .NET 3.5 to use Expression and also has
some ramifications on how ContraintExpressions work in general. Pushing
it to NUnit 3.0, where we will have separate builds for .NET 2.0, 3.5
and 4.0.
** Project changed: nunitv2 => nunit-3.0
** Changed in: nunit-3.0
Milestone: 2.6.0 => None
--
You received this bug notification because you are a member of NUnit
Core Developers, which is the registrant for NUnit Framework.
https://bugs.launchpad.net/bugs/901192
Title:
Feature request: Provide a strongly typed variant of the Property
constraint
Status in NUnit Test Framework:
Triaged
Bug description:
Currently, NUnit supports a number of generic constraints that define
the type of the tested expression at compile time (if they succeed):
Is.TypeOf<T>(), Is.AssignableTo<T>(), and Is.InstanceOf<T>(). (Note
that Is.AssignableFrom<T>() is not a candidate for this feature
request because it only defines a derived type!)
Those constraint factory methods currently return instances of non-
generic expression types (e.g., ExactTypeConstraint, etc.) that
inherit the ordinary, untyped constraint expression factory methods,
so that you can write, for example: Is.TypeOf<object>().With.Property
("P").EqualTo (42). Note that when "With" is called, the type
information specified at the TypeOf<T> call gets lost and the Property
constraint needs to take the property name by string rather than, for
example, by expression.
Passing the property name as string is bad as an invalid name will not
trigger a compile-time error and as automated refactorings (e.g.,
renaming the property) will not take notice of the property name.
Therefore, change TypeOf<T>, AssignableTo<T>, and InstanceOf<T> to
return generic subclasses of the contraint types (e.g.,
ExactTypeConstraint<T>) that redefine Constraint.With to retain the
type information. Provide generic variants of ConstraintExpression and
ResolvableConstraintExpression to allow for nested strongly typed
constraints. Then provide a generic version of the Property constraint
factory method.
Here is what the code could look like for NUnit 2.6 (with non-breaking
changes).
public class ExactTypeConstraint<T> : ExactTypeConstraint
{
public new ConstraintExpression<T> With { get { ... } }
}
public class ConstraintExpression<T> : ConstraintExpression
{
public new ConstraintExpression<T> With { get { ... } }
public new ConstraintExpression<T> And { get { ... } }
// ...
public ResolvableConstraintExpression<T> Property<TR> (Expression<Func<T, TR>> propertyAccessor);
}
public class ResolvableConstraintExpression<T> : ResolvableConstraintExpression
{
public new ConstraintExpression<T> With { get { ... } }
public new ConstraintExpression<T> And { get { ... } }
}
That way, one could write constraints similar to:
Is.TypeOf<object>().With.Property (o => o.P).EqualTo (42).And.Property (o => o.P2).EqualTo (43)
To manage notifications about this bug go to:
https://bugs.launchpad.net/nunit-3.0/+bug/901192/+subscriptions
References