我正在为 IBM Db2 数据库的 LINQPad 构建动态上下文驱动程序。我一直在测试驱动大部分代码,我想我已经完成了我需要的关于我需要的数据库的所有信息。(我以后可能需要更多,但现在似乎足够了)。我下载了 PostgreSQL 上下文驱动程序的 git 存储库,并查看(某种程度上)它是如何构建的。没有足够的测试让我对自己正在构建程序集充满信心。但是后来我开始考虑是否要开始构建这个动态程序集,我不知道如何测试它。我想从这样简单的开始:
[TestFixture]
public class Db2DynamicAssemblyBuilderTests
{
[Test]
public void DynamicClassHasMatchingNameAsTable()
{
List<Models.Db2TableInformation> tableInformation = new List<Models.Db2TableInformation>();
tableInformation.Add(new Models.Db2TableInformation()
{
Schema = "Schema",
TableName = "TableName"
});
AssemblyName assemblyToBuild = new AssemblyName(@"c:\temp\someassembly.dll");//somehow build this with a dynamic name???? i'll figure this out
string nameSpace = "LINQPad.User";
string typeName = "TypeDataContext";
var target = new Db2DynamicAssemblyBuilder(assemblyToBuild, nameSpace, typeName);
target.Build(tableInformation);
//??? Load assembly?
//Get Class LINQPad.User.Schema.TableName (or maybe just LINQPad.User.TableName...not sure yet)
}
}
那么这是正确的方法吗?我会这样做吗?