 geBTC
		
		
		
		
		
		
		
		
	
			 on 
    
	
		
		
		05-13-2015
	
		
		10:16 AM
	
	
	
	
	
	
	
	
	
	
	
	
	
	
		
	
				
		
			1 Comment (1 New)
		
			geBTC
		
		
		
		
		
		
		
		
	
			 on 
    
	
		
		
		05-13-2015
	
		
		10:16 AM
	
	
	
	
	
	
	
	
	
	
	
	
	
	
		
	
				
		
			1 Comment (1 New)
		
	
		
Because of the way .NET applications and assemblies are invoked in TestStand they are a child process of TestStand. This means that they share TestStand's resources. For most applications this is not an issue but if the application or library being instrumented by TestStand is resource intensive this creates a significant problem. In the scenario that served as the impetus for this suggestion we saw performance 1/10 that when running the target application outside of TestStand.
To correct this I recommend the .NET adapter architecture be changed or be able to be configured such that instead of directly instantiating target applications a call to create an object with a .NET adapter would create a separate process that consisted of a TestStand WCF client wrapper process that would host the target .NET process and communicate with the parent TestStand instance via WCF.
Here is a simple block diagram of the intended architecture:
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
We explored this approach. For most common use cases with smaller & fewer .NET assemblies, the performance of out-of process calls was found to be 8-10X worse than calling them in-process. The better performances you are observing perhaps holds true for larger applications.
There isnt a great way to provide a way to switch between the 2 approaches. Hence declining this request for now.