是什么原因:Unix传输错误?

时间:2010-12-03 09:41:53

标签: nhibernate postgresql nunit

我在Postgresql上进行单元测试(使用NUnit),不幸的是它会导致错误:

Internal error
    RemotingException: Unix transport error.

注意:如果我使用的是Sqlite

,则不会发生错误

代码:

 using System;
 using ncfg = NHibernate.Cfg;
 using System.Collections.Generic;
 using System.Reflection;
 using NHibernate;
 using System.Data;
 using NHibernate.Tool.hbm2ddl;
 using NHibernate.Dialect;
 using NHibernate.Driver;
 using NHibernate.ByteCode.LinFu;
 using NUnit.Framework;
 using NHibernate.Mapping;



 namespace RuntimeNhibernate
 {
  class MainClass
  {
   public static void Main (string[] args)
   {


    using(var c = new BlogTestFixture())
    {
     c.CanSaveAndLoadBlog();

    }

   }
  }



  public class InMemoryDatabaseTest : IDisposable
  {
   private static ncfg.Configuration Configuration;
   private static ISessionFactory SessionFactory;
   protected ISession session;

   public InMemoryDatabaseTest(Assembly assemblyContainingMapping)
   {
    if (Configuration == null)
    {

     Configuration = new ncfg.Configuration()
      .SetProperty(ncfg.Environment.ReleaseConnections,"on_close")
      .SetProperty(ncfg.Environment.Dialect, typeof (SQLiteDialect).AssemblyQualifiedName)
      .SetProperty(ncfg.Environment.ConnectionDriver, typeof(SQLite20Driver).AssemblyQualifiedName)
      .SetProperty(ncfg.Environment.ConnectionString, "data source=:memory:")
      .SetProperty(ncfg.Environment.ProxyFactoryFactoryClass, typeof (ProxyFactoryFactory).AssemblyQualifiedName)
      .AddAssembly(assemblyContainingMapping);


     /*Configuration = new ncfg.Configuration()
      .SetProperty(ncfg.Environment.ReleaseConnections,"on_close")
      .SetProperty(ncfg.Environment.Dialect, typeof (PostgreSQLDialect).AssemblyQualifiedName)
      .SetProperty(ncfg.Environment.ConnectionDriver, typeof(NpgsqlDriver).AssemblyQualifiedName)
      .SetProperty(ncfg.Environment.ConnectionString, "Server=127.0.0.1;Database=memdb;User ID=postgres;Password=password;Pooling=false;")
      .SetProperty(ncfg.Environment.ProxyFactoryFactoryClass, typeof (ProxyFactoryFactory).AssemblyQualifiedName)
      .AddAssembly(assemblyContainingMapping);*/

     SessionFactory = Configuration.BuildSessionFactory();
    }

    session = SessionFactory.OpenSession();

    new SchemaExport(Configuration).Execute(true, true, false, session.Connection, Console.Out);
   }

   public void Dispose()
   {
    session.Dispose();
   }
  }//class InMemory

  public class Blog
  {
   public virtual int BlogId { get; set; }
   public virtual bool AllowsComments { set; get; }
   public virtual DateTime CreatedAt { get; set; }
   public virtual string Subtitle { get; set; }
   public virtual string Title { get; set; }
  }

  [TestFixture]
  public class BlogTestFixture : InMemoryDatabaseTest
  {
   public BlogTestFixture() : base(typeof(Blog).Assembly)
   {
   }


   [Test]
   public void IsOK()
   {
    Assert.AreEqual(true, true);
    return;
   }

   [Test]     
   public void CanSaveAndLoadBlog()
   {


    object id;




    using (var tx = session.BeginTransaction())
    {
     id = session.Save(new Blog
     {
      AllowsComments = true,
      CreatedAt = new DateTime(2000,1,1),
      Subtitle = "Hello",
      Title = "World",
     });

     tx.Commit();
    }

    session.Clear();

    Console.WriteLine("Hello {0}", id);


    using (var tx = session.BeginTransaction())
    {
     var blog = session.Get<Blog>(id);




     Assert.AreEqual(new DateTime(2000, 1, 1), blog.CreatedAt);
     Assert.AreEqual("Hello", blog.Subtitle);
     Assert.AreEqual("World", blog.Title);
     Assert.AreEqual(true, blog.AllowsComments);

     tx.Commit();
    }
   }
  }//Test


 }//namespace

当我对Postgresql进行单元测试时,可能是什么原因导致 RemotingException:Unix传输错误。

如果我在单元测试之外运行代码(例如Main),它就可以工作。顺便说一句,如果我单元测试Sqlite,它也不会导致任何错误

2 个答案:

答案 0 :(得分:0)

找到答案,我尝试从终端(/Applications/MonoDevelop.app/Contents/MacOS/monodevelop)启动MonoDevelop,我在运行单元测试时看到了命令行中更详细的错误

Unhandled Exception: System.TypeInitializationException: An exception was thrown by the type initializer for Npgsql.NpgsqlConnection ---> System.TypeLoadException: Could not load type 'System.Runtime.Versioning.TargetFrameworkAttribute' from assembly 'Npgsql'.
  at (wrapper managed-to-native) System.MonoCustomAttrs:GetCustomAttributesInternal (System.Reflection.ICustomAttributeProvider,System.Type,bool)
  at System.MonoCustomAttrs.GetCustomAttributesBase (ICustomAttributeProvider obj, System.Type attributeType) [0x00000] in <filename unknown>:0 
  at System.MonoCustomAttrs.GetCustomAttributes (ICustomAttributeProvider obj, System.Type attributeType, Boolean inherit) [0x00000] in <filename unknown>:0 
  at System.Reflection.Assembly.GetCustomAttributes (System.Type attributeType, Boolean inherit) [0x00000] in <filename unknown>:0 
  at System.Resources.ResourceManager.GetNeutralResourcesLanguage (System.Reflection.Assembly a) [0x00000] in <filename unknown>:0 
  at System.Resources.ResourceManager..ctor (System.Type resourceSource) [0x00000] in <filename unknown>:0 
  at Npgsql.NpgsqlConnection..cctor () [0x00000] in <filename unknown>:0 
  --- End of inner exception stack trace ---
  at (wrapper managed-to-native) System.Reflection.MonoCMethod:InternalInvoke (System.Reflection.MonoCMethod*,object,object[],System.Exception&)
  at System.Reflection.MonoCMethod.Invoke (System.Object obj, BindingFlags invokeAttr, System.Reflection.Binder binder, System.Object[] parameters, System.Globalization.CultureInfo culture) [0x00000] in <filename unknown>:0 

然后我尝试将Npgsql版本(导致错误的版本来自http://pgfoundry.org/frs/download.php/2868/Npgsql2.0.11-bin-ms.net4.0.zip)更改为http://pgfoundry.org/frs/download.php/2860/Npgsql2.0.11-bin-mono2.0.zip此后,不再有 Unix传输错误 ^ _ ^

获得的经验教训,如果您在Mono上运行东西,请使用您正在使用的组件的Mono版本

答案 1 :(得分:0)

当MonoDevelop中的单元测试引发异常时,会出现此异常,该异常无法被测试运行器捕获(即,当测试启动某些线程并且它们崩溃时)。

如果您有这样的测试,即使在运行

之后也是灰色的

not executable test

并且单元测试板显示内部错误

enter image description here

您应该尝试使用nunit-console在您的控制台上运行测试(应该在mono来自的发行版的回购中)并泄漏异常。

就我而言,在我的测试的子线程中,这是一个简单的多枚举异常。

Unhandled exceptions:
1) Residata.Platform.Server.Message.Test.MemoryBrokerTest.AssertThatReceiveMethodWaitsUntilPublish : System.InvalidOperationException: Collection was modified; enumeration operation may not execute.
   at System.Collections.Generic.List`1+Enumerator[Residata.Platform.Contract.Message.IPackage].MoveNext () [0x00000] in <filename unknown>:0