1

我正在使用一个类测试来检查正在正确完成的登录实体,但发生错误似乎没有返回数据库中的查询,但是在 ASP.NET MVC 3 Code First 查询中开发的应用程序返回数据,我想知道什么是错的以及可以做些什么来解决它。

查询返回后,变量中会显示以下消息: “枚举未产生结果”

测试方法:

[TestMethod()]
public void efetuarLoginTest()
{
            EntidadeRepository target = new EntidadeRepository();
            string cnpj = "12345678";
            string senha = "lalado";
            Entidade expected = null; // TODO: Initialize to an appropriate value
            Entidade actual;
            actual = target.efetuarLogin(cnpj, senha);
            Assert.AreNotEqual(expected, actual);
}

具有返回登录查询任务的实体的方法存储库:

public Entidade efetuarLogin(string cnpj, string senha)
        {

            var consulta = from usu in bd.Entidades
                           where usu.cnpj == cnpj && usu.senha == senha
                           select usu;

            if (consulta.Count() > 0)
            {
                Entidade e = new Entidade();
                e.id_entidade = consulta.First().id_entidade;
                e.razao_social = consulta.First().razao_social;
                e.cnpj = consulta.First().cnpj;
                e.senha = consulta.First().senha;

                return e;
            }
            else
            {
                return null;
            }
        }

使用 Entity Framework 4.1 的类持久性数据库:

internal class BancoDados: DbContext
    {
        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            modelBuilder.Conventions.Remove<System.Data.Entity.ModelConfiguration.Conventions.PluralizingEntitySetNameConvention>();
            modelBuilder.Conventions.Remove<System.Data.Entity.ModelConfiguration.Conventions.PluralizingTableNameConvention>();

            base.OnModelCreating(modelBuilder);
        }

        public DbSet<Entidade> Entidades { get; set; }
        public DbSet<Estado> Estados { get; set; }
        public DbSet<Administrador> Administradores { get; set; }
        public DbSet<Leilao> Leiloes { get; set; }
        public DbSet<Lance> Lances { get; set; }
    }

谢谢你。

4

2 回答 2

0

我会想象

if (consulta.Count() > 0)

抛出错误?

你可以把它改成

if (consulta != null && consulta.Count() > 0)
于 2012-10-12T17:07:43.580 回答
0

对我们来说,这种错误是由于没有传递给 EF 的正确连接字符串而产生的。如果您使用的是 NUnit,NUnit 不使用您的 app.config 或 web.config,您必须创建您的 assembly.dll.config 或 nunit project.config。请查看 NUnit 文档以了解配置文件的使用。

您可以通过在调试模式下检查 DbContext.Database 及其属性来验证传递给 NUnit 的连接字符串/

检查您的配置值,应该可以解决您的问题。

于 2012-10-13T13:16:59.103 回答