Как проверить генерацию таблиц с помощью nhibernate (schemaexport)? в контексте asp.net
Ну, это мой самый первый проект с беглым hibernate. У меня был небольшой опыт работы в hibernate и nhibernate.
Этот контекст для меня совершенно новый, поскольку это проект веб-приложения. Так что у меня есть мой проект веб-приложения с большей частью свободного nhibernate, найденного в сети. так что у меня есть эти лица:
namespace myproject.model
{
public class Request
{
public virtual string Id { get; private set; }
public virtual Route route { get; set; }
public virtual int code { get; set; }
}
}
namespace myproject.model
{
public class Route
{
public virtual string Id { get; private set; }
public virtual string client_id { get; set; }
public virtual IList<Request> requests { get; set; }
public Route()
{
requests = new List<Request>();
}
}
}
//Mapping are like this.will only post one
namespace myproject.mappings
{
public class RequestMap : ClassMap<Request>
{
public RequestMap()
{
Id(x => x.Id);
Map(x => x.short_code);
References(x => x.route);
}
}
}
//NhibernateSessionPerRequest
namespace myproject.Boostrap
{
public class NhibernateSessionPerRequest : IHttpModule
{
private static readonly ISessionFactory _sessionFactory;
static NhibernateSessionPerRequest()
{
_sessionFactory = CreateSessionFactory();
}
//all others IHttpModule event and methods are here
private static ISessionFactory CreateSessionFactory()
{
FluentConfiguration configuration = Fluently.Configure().Database(MsSqlConfiguration.MsSql2005.
ConnectionString(x => x.FromConnectionStringWithKey("localdb")))
.Mappings(m => {
m.FluentMappings.AddFromAssemblyOf<myproject.model.Request>();
m.FluentMappings.AddFromAssemblyOf<myproject.model.Route>();
}
).ExposeConfiguration((c)=> savedConfig = c);;
return configuration.BuildSessionFactory();
}
}
private static Configuration savedConfig;
public static void BuildSchema(NHibernate.Cfg.Configuration config)
{
new SchemaExport(config).Create(false, true);
}
public static void BuildSchema(ISession session)
{
var export = new SchemaExport(savedConfig);
export.Execute(false,true,false,session.Connection,null);
}
}
Я добавил модуль в webconfig
<add name="NhibernateSessionPerRequest" type="myproject.Boostrap.NhibernateSessionPerRequest"/>
чтобы проверить генерацию таблиц, я добавил тестовый проект (библиотеку классов), добавил ссылку на nunit.framework 2.8.5 и myproject.
namespace myproject.Tests
{
[TestFixture]
public class CanGenerateSchemaTestSuite
{
[Test]
public void CanGenarateSchema()
{
NhibernateSessionPerRequest.BuildSchema(NhibernateSessionPerRequest.GetCurrentSession());
}
}
}
метод теста всегда терпит неудачу, и у меня есть это исключение:
CanGenerateSchemaTestSuite (1 тест), 1 тест не пройден: дочерний тест не пройден CanGenarateSchema, Failed: System.TypeInitializationException
так как тестирование проводится в контексте asp.net?? спасибо за чтение этого. спасибо
2 ответа
Просто смутный комментарий о другом решении; для этого вам не нужно полностью удалять файлы базы данных; просто бросьте столы:
.ExposeConfiguration(SetupTestDatabase)
...
private static void SetupTestDatabase(NHibernate.Cfg.Configuration config)
{
var schema = new SchemaExport(config);
schema.Drop(true, true);
schema.Create(true, true);
}
Это просто означает, что вы можете запускать свои тесты в другой базе данных, ничего не меняя.
Редактировать; Woops; думал, что это было принято решение. Если вы делаете это в тесте, просто сделайте это так:
[Test]
public void Test_can_store_and_get_objects()
{
var factory = CreateSessionFactory();
using (var s = factory.OpenSession())
{
...
}
}
private static ISessionFactory CreateSessionFactory()
{
return Fluently.Configure().Database(SQLiteConfiguration.Standard.UsingFile("firstProject.db"))
.Mappings(m => m.FluentMappings.AddFromAssemblyOf<Address>()) // <-- Refer to parent project
.ExposeConfiguration(SetupTestDatabase)
.BuildSessionFactory();
}
Вот мой пример. Вам нужно использовать ExposeConfiguration
и передать метод, который принимает конфигурацию, и вы просто создаете базу данных там и затем с помощью SchemaExport
:
class SqliteRefSessionFactoryProvider : ISessionFactoryProvider
{
public const string SqliteRefFileName = "ref.db";
public ISessionFactory GetSessionFactory()
{
return Fluently.Configure().Database(
SQLiteConfiguration.Standard.UsingFile(SqliteRefFileName).ShowSql())
.Mappings(m => m.FluentMappings.AddFromAssemblyOf<SsoToken>())
.ExposeConfiguration(BuildSchema)
.BuildSessionFactory();
}
private static void BuildSchema(NHibernate.Cfg.Configuration configuration)
{
if (File.Exists(SqliteRefFileName))
File.Delete(SqliteRefFileName);
new SchemaExport(configuration)
.Create(false, true);
}
}