Почему hbm2ddl.SchemaExport здесь не запускается? - PullRequest
5 голосов
/ 19 января 2011

Попытка поиграться с IInterceptor в NHibernate 2.1.2.4000 У меня есть следующий бит тестового кода:

public class TestingNHibernateInterceptors
{
    [Fact]
    public void can_intercept_delete_for_audit_log()
    {
        FullyConfigureDb();
        Session(s => s.Linq<Person>().Any().ShouldBe(false));
    }
    ISessionFactory _sessions;
    void Session(Action<ISession> @do)
    {
        using (var s = _sessions.OpenSession())
        {
            @do(s);
            s.Flush();
        }
    }
    void FullyConfigureDb()
    {
        var cfg = CreateConfig();
        _sessions = cfg.BuildSessionFactory();
        BuildSchema(cfg);
    }
    Configuration CreateConfig()
    {
        return Fluently.Configure()
            .Database(new SQLiteConfiguration().InMemory())
            .Mappings(x => x.FluentMappings.Add<PersonMap>())
            .BuildConfiguration()
            .SetProperty("proxyfactory.factory_class", "NHibernate.ByteCode.Castle.ProxyFactoryFactory, NHibernate.ByteCode.Castle")
            .SetProperty("show_sql", "true");
    }
    void BuildSchema(Configuration config)
    {
        var se = new NHibernate.Tool.hbm2ddl.SchemaExport(config);
        se.Execute(false, true, false, _sessions.OpenSession().Connection, null);
    }
    public class Person
    {
        public virtual Guid Id { get; private set; }
        public virtual string Name { get; set; }
    }
    public class PersonMap : ClassMap<Person>
    {
        public PersonMap()
        {
            Id(x => x.Id);
            Map(x => x.Name);
        }
    }
    public class AuditInterceptor : EmptyInterceptor, IInterceptor
    {
        public override void OnDelete(object entity, object id, object[] state, string[] propertyNames, NHibernate.Type.IType[] types)
        {
            base.OnDelete(entity, id, state, propertyNames, types);
        }
    }
}

Однако.Я продолжаю получать сообщение:

не удалось: NHibernate.ADOException: не удалось выполнить запрос [SELECT count (*) как y0_ ОТ "Person" this_] [SQL: SELECT count (*) при y0_ FROM"Person" this_] ---- System.Data.SQLite.SQLiteException: ошибка SQLite

Кажется, что экспорт схемы работает - почему таблица не создается?

IЯ предполагаю, что это как-то связано с использованием sqllite в памяти, но не уверен, в чем проблема.Есть идеи?

1 Ответ

3 голосов
/ 26 января 2011

Был там, сделал это, тоже пострадал; -)

Как только сеанс освобожден, база данных в основном удаляется.Поскольку при построении схемы и при выполнении тестов вы используете разные сеансы, схема больше не существует во время выполнения теста.

См. сообщение от Джастин для очень четкого объяснения.

...