0

私はmvc2フレームワークを使用してasp.netmvcアプリケーションに取り組んでいます。

これがその見方です。

<% using (Ajax.BeginForm("CreateMenuCategory",
           "Admin", 
           new AjaxOptions { UpdateTargetId = "tabs-MenuCategories", }))
       { %>
       <fieldset class="fields">
           <legend>
                Add Menu Categories
            </legend>
            <p>
                <label for="MenuCategoryName">MenuCategory Name:</label>
                <%= Html.TextBox("MenuCategoryName")%>
                <%= Html.ValidationMessage("MenuCategoryName")%>
            </p>
            <p>
                <label for="Description">Description</label>
                <%= Html.TextBox("Description")%>
                 <%= Html.ValidationMessage("Description")%>
            </p>               
            <p>
                <label for="Notes">Notes</label>
                <%= Html.TextBox("Notes")%>
            </p>        
             <p class="submit">
                    <input type="submit" value="Create" />
             </p>       
    </fieldset>
    <% } %>

これがモデルバインディングに使用したクラスです

public class MenuCategoryBusinessObject
    {


        //private readonly IMenuRepository _repository;
        public int ID { get; set; }

        [Required]
        [StringLength(20)]
        public string MenuCategoryName { get; set; }

        [Required]
        [StringLength(20)]
        public string Description { get; set; }

        public string Notes { get; set; }

        public IEnumerable<MenuItemBusinessObject> MenuItems
        {
            get; set;
        }

    }

そして、これが私のコントロールです

 [HttpPost]
    public ActionResult CreateMenuCategory([Bind(Exclude = "ID")]MenuCategoryBusinessObject  menuCategory)
    {

        if(ModelState.IsValid)
        {//if I am valid.
            _repository.CreateMenuCategory(menuCategory);
        }

        IndexMenuCategory model = new IndexMenuCategory
        {
            MenuCategories = _repository.GetMenuCategories(),
            SelectedMenuCategory = null

        };
        return PartialView("MenuCategories", model);
    }

モデルのバインドを行うと、データアノテーションの検証では、モデルが無効であり、ModelState.IsValidがfalseであることがすでに認識されています。

ただし、単体テストを実行するときに、独自のMenuCategoryBusinessObjectをactionメソッドにフィードすると、modelbindingがバイパスされ、ModelStateが無効であることがわかりません。

 [Fact]
    public void CreateNewMenuCategory()
    {
        // Setup
        DataStore dataStore = new DataStore();
        IMenuRepository menuRepository = new MenuRepository(dataStore);
        MenuCategoryBusinessObject menuCategoryBusinessObject =
            new MenuCategoryBusinessObject();
        AdminController adminControl = new AdminController(menuRepository);
        adminControl.SetFakeControllerContext();
        adminControl.Request.SetHttpMethodResult("POST");

        // Execute
        adminControl.CreateMenuCategory(menuCategoryBusinessObject);
    }

だから、私の質問は、この状況でどのように効果的にユニットテストを行うことができるかということです。

4

2 に答える 2

2
controllerInstance.ModelState.AddModelError("", "Dummy value.");

メソッドが呼び出される前にダミー値を追加すると、IsValidフラグがクリアされます。次に、アクション メソッドを呼び出して、この特定のコード パスをテストします。

于 2009-11-02T20:29:57.187 に答える
0

モデルが正しくデータ注釈が付けられているかどうかをテストするために、おそらく次の行の中で何かをするでしょう:

[TestMethod]
public void Description_Should_Be_Required()
{
    Expression<Func<MenuCategoryBusinessObject, object>> expression = 
        o => o.Description;
    var me = expression.Body as MemberExpression;
    var att = (RequiredAttribute[])me.Member
              .GetCustomAttributes(typeof(RequiredAttribute), false);
    att.Length.ShouldEqual(1);
}

テストする必要があるDataAnnotationsModelBinderもう 1 つのことは、デフォルトの代わりに を効果的に使用していることです。

ModelBinders.Binders.DefaultBinder = new DataAnnotationsModelBinder();
于 2009-10-31T11:16:04.547 に答える