|
Pete O'Hanlon wrote: Have you looked into Pex[^]? It's an interesting concept, to say the least.
From what I can tell, Pex looks like a brute-force solution to unit testing--it solves some of the coverage problems in TDD by attempting to quantify every possible input and output that might come out of a single method. There's two problems to this approach: 1) Observability, and 2) Isolating the component to be tested.
The first problem of observability has a lot to do with the software engineering equivalent of the Uncertainty Principle--how do you observe the behavior of an app without having to modify it? For example, if I wanted to test the DAL of a legacy app and that application has a tightly-coupled architecture, how do you verify the behavior of the DAL without modifying its architecture to support unit testing? With Pex, you can only test the components of an architecture if their behavior can be "observed" by the unit tests generated by Pex; however, in a legacy app, you might not have the luxury of modifying the architecture to support those unit tests.
The isolation problem rears its ugly head when you have legacy code that is ridden with "copy & paste" code. In order to use automated unit testing (much less Pex), you would have to refactor out the duplication and then mock out the components around the component to be tested, and then test the component itself. Once you have the component isolated, it is then (and only then) that you can throw Pex at it and have it do its brute-force approach to finding holes in your code.
The problem with using Pex with legacy apps is that the approach might be too invasive. In the current state of automated unit testing and TDD, this is akin to giving bypass surgery to a patient who just wants a medical checkup. What I want to do is diagnose the patient (per se) without killing them in the process. IMHO, we're practically in the Dark Ages when it comes to diagnosing legacy apps, and that has to change.
|
|
|
|
|
If you need to unit test legacy code, code that isn't particularly designed for mockability (or isn't designed for it at all), there is nothing that comes close to the TypeMock Isolator. TypeMock lets you mock absolutely anything, any time, for any reason, regardless of what it is. You can mock statics, replace function calls, whatever you need to. It allows you to fully isolate your unit of interest and actually perform "unit" testing for any code, regardless of whether it actually supports unit testing.
Many people will jump on this with a vehement revulsion and provide blanket statements that you should refactor all of your code so its better architected and is properly mockable. In the long run, yes, you should eventually improve your code base. But when your on a budget and need that full safety net of tested code, TypeMock is a godsend. You can, basically, have your cake and eat it too. I hope it helps.
http://www.typemock.com/
|
|
|
|
|
You're right - I am going to jump on this post. In fact, I'm going to jump all over it and say - interesting, I'll go and have a look at it now.
|
|
|
|
|
LOL, let me know what you think. I'm still evaluating it myself, but and it does have a couple drawbacks (i.e. the isolator is a 'wrapper' program that must be running for method intercepts and the like to function during execution, and it costs money). When it comes to testing locked-down legacy code, though, its truely unique.
|
|
|
|
|
Class A
{
B bsObject;
public void FunctionOfClassA()
{
bsObject.FunctionOfClassB()
}
}
Class B
{
public void FunctionOfClassB()
{
}
}
I have my program structure as shown above.
I want a way to apply atomicity to this. I mean if Class B's data write worked fine but Class A's calculations failed then want to rollback the data write. i want it all succeed or rollback.
One way i can think of is to create a DB ptr and begin transaction just before call to FunctionOfClassB() and pass it as a parameter. so in this FunctionOfClassB will use same db ptr to write data. And it would also be possible in FunctionOfClassA() to check if calculations went ok then commit or rollback.
My requirement is to not to make any change in parameter list or not to provide a new method with new parameter.
Class A
{
B bsObject;
public void FunctionOfClassA()
{
bsObject.FunctionOfClassB()
// some calculations
// Here I want to decide whether to commit or rollback
}
}
Class B
{
public void FunctionOfClassB()
{
// here i want to begin a transaction
// some data writing.
}
}
Can anyone give an high level summary how this could be possible?
|
|
|
|
|
paresh_joe wrote: I want a way to apply atomicity to this.
this? The code you posted has no data, there are no write operations, therefore nothing to roll forwards or backwards, even sideways.
led mike
|
|
|
|
|
paresh_joe wrote: My requirement is to not to make any change in parameter list or not to provide a new method with new parameter.
If so as above, then how can you (down below) pass the pointer since your function accepts no parameters in your skeleton class.
paresh_joe wrote: One way i can think of is to create a DB ptr and begin transaction just before call to FunctionOfClassB() and pass it as a parameter.
Please reword.
|
|
|
|
|
I meant to say that only solution come to my mind is to pass DB parameter to function which is not possible. I want some other way in which this can be implemented.
|
|
|
|
|
Can the server function throw an exception if transaction is not completed? Yes, then you can handle it in the client and do whatever you need to. Another approach is, if you can, to introduce two events in the server method which can be raised when the server method either completes or fails. This event will have one parameter derived from the EventArgs class (if using .NET) and it can contain information about what happened during the transaction--what failed and what passed.
What do you think?
|
|
|
|
|
I REALLY DONT KNOW.........PLS HELP
|
|
|
|
|
I don't understand what you are asking. You are back after a long time! Can you be more clear about your question?
CodingYoshi
Visual Basic is for basic people, C# is for sharp people. Farid Tarin '07
|
|
|
|
|
|
|
|
|
Current Scenario:
I have a long running application that gets a job list from sql, creates a child process for each request and exchange status data with those child process with a full-duplex communication.
All processes runs on the same machine as the host application, currently all processes are Win32 and I use WM_COPYDATA.
Future:
It is likely that in the next future the Win32 application will be rewritten to .NET, child processes will remain untouched, new child processes will be written in any language/platform (.NET, Win32) depending on 3rd party specifications/libraries.
Question:
I would like to hear some rant on how to implement interprocess communication between .NET and Win32 application.
TIA
|
|
|
|
|
You could convert the WM_COPYDATA-solution to a C#-counterpart. Windows-messaging is fast, and you'd retain compatibility with the old version.
Alternatively you could use a HttpServer, and use WebRequests; easier to debug than Windows-messages, and you can send/receive messages from beyond the local desktop.
I are troll
|
|
|
|
|
This is a simple class I am building to abstract some functionality. Pay attention to my use of assertions.
///
/// Encapsulates execution of queries.
///
public class QueryExecutor
{
/// summary
/// Returns a DataTable object populated using the specified parameters.
/// summary
/// param name="connectionString" // the connection string to use
/// param name="queryType" //
/// param name="queryText"
/// returns
public static DataTable GetTable(string connectionString, CommandType queryType, string queryText)
{
Trace.Assert(queryText != null, "QueryExecutor::GetData\nQuery must not be null.");
Trace.Assert(queryText != string.Empty, "QueryExecutor::GetData\nQuery must not be empty.");
Trace.Assert(connectionString != null, "QueryExecutor::GetData\nConnection must not be null.");
Trace.Assert(connectionString != string.Empty, "QueryExecutor::GetData\nConnection must not be empty.");
SqlConnection connection = new SqlConnection(connectionString);
SqlCommand query = connection.CreateCommand();
query.CommandType = queryType;
query.CommandText = queryText;
SqlDataAdapter adapter = new SqlDataAdapter(query.CommandText, connection);
DataTable table = new DataTable();
try
{
adapter.Fill(table);
}
catch (SqlException)
{
ReleaseResources(adapter, connection);
throw;
}
catch (Exception)
{
ReleaseResources(adapter, connection);
throw;
}
return table;
}
private static void ReleaseResources(SqlDataAdapter adapter, SqlConnection connection)
{
adapter.Dispose();
if (connection.State == ConnectionState.Open)
connection.Close();
}
}
I am trying to fully understand the difference between assertions and exceptions. According to readings I have read, I have come to conclusion that assertions are used for errors which should never occur and thus programmers can fix it, and for class invariances. In other words it warns the programmer and helps the programmer know that the code is actually doing what it was intended to do. Exception on the other hand can not be fully avoided but they can be anticipated and gives the opportunity to deal with it somehow during runtime. For example, if the application is trying to read a file from a path provided by the user and the file does not exist, the programmer can not really do anything but throw exception and application will handle it. Then application will tell the user that file does not exist.
My questions now are:
1. In my class above, according to my understanding which I explained above, the programmer should give me a connection string at least, therefore, I am asserting that connection string can not be empty or null. This is an error which should never occur so I am using assertion instead of throwing exception. Is this ok? Wow...I just came up with a thought (funny how when you are asking a question you come up with more questions): What if the caller is reading the connection string from a file and sending it over, now I am not giving the caller the opportunity to handle the error and try again or something. But still the caller should at least verify that the string is not empty or null.
2. Another question is why should I use Trace and not Debug apart from the known fact that Trace is bundled up with release versions but Debug is not.
3. What else is wrong with my style of coding? I know it needs more work to handle TableDirect or simple query.
4. Any other suggestions?
Thanks,
|
|
|
|
|
Have a google for "Design by Contract" and "nContract".
|
|
|
|
|
Thanks for the answer but I am designing based on design by contract. I was hoping someone can answer my questions which were unanswered even after numerous reads. I am still waiting for an answer as that does not help me whatsoever. I have read so many readings based on this topic and seems like not too many people understand it, hence the reason for only 1 reply to my question.
|
|
|
|
|
Ah ok, well I'll put in my 2c on your questions then.
1. Assertions and Exceptions are pretty different concepts. Assertions are a test that you absolutely expect to succeed, and indicates a design/breach of contract error if it fails. A failing assertion needs to perform an action, and this would commonly be throwing an exception (or getting a TraceListener to do something). I'd tend towards throwing an ArgumentException in these cases.
2. Trace is like Debug. Instead of the DEBUG conditional compilation constant, it is dependant on TRACE being defined (which is defined in release mode by default).
3. It won't compile. ReleaseResources can't see adapter or connection due to scoping. Even if you made these static, your method wouldn't be thread-safe.
4. IMO theres no need to "enterprise" up a DAL with all sorts of abstraction if you are doing simple enough things that could be handled by the built-in IDE databinding. If you do need a proper ORM solution, then coding one by hand with sufficient functionality is going to take a long time.
|
|
|
|
|
Hello evrybody.
If I'd like to do a simple application that would collect/track user behavior on the interface (how he is navigating, is he kind of seraching for something,etc) in order to make a short term prediction and help the user by somekind of notification or intelligently update the content of a certain help-topic preview so the user may find help kwikly.. then how can I do such thing in a proper, organizable way ?
What is the proper way to represent the incoming inputs that I am going to reason on..How would be the reasoning sheme for that ?
I'm posing the kestion to see if somebody can direct me at existing solutions based on that, possible techniques that are employed in such case, even links,etc. I will also be happy to open a detailed discussion that would be fruitful to evrybody.
For instance I found this link :
http://www.cwsandbox.org/?page=home[^]
It is about kind of antivirus I think that bases its decisions on the understanding of application behvior. (That's what they say at least). I wonder how the input is organized, how the reasoning is done. Well this is an example that I found it. It proves there are many such cases.
Do you have links for application in same philosophy.
I'm eager to enter this domain, and learn about it.
Thank you in advance.
|
|
|
|
|
Hello everybody,
Months ago, I started having some fun writting a POS (Point Of Sale) system for Restaurants. But as I keep developing it, it got to the point that it is getting very reach in functionalities. So, I decided to go a little further. I decided to make some profit by sellling this software.
I am using VB 2005 Express as my plataform and SQL 2005 as my database ( it can easily be switched from MS SQL 2005 to MS Access 2007).
Since I am developing this POS sytem with VB 2005 express and SQL 2005 express, which can be downloaded for free from Microsoft.com, can I install my POS system on any computer and download the free downloaded SQL 2005 express on those computers? Or in the case of using MS Access 2007, can I just install the the run time files?
Since I am just starting to open myself in the business world, I don't think I will be able to afford to pay for using .NET products. I already have made some budget for purchasing all the physical things for this POS System such as Computers, Label printers, scanners, etc...
Is there any one who has gone through this experience?
I will be glad to hear any comments from anyone of you.
Thanks everyone in advance.
Sincerely,
Tommy4U
aaquino04@hotmail.com
|
|
|
|
|
You need to check the redistribution rights for all libraries you use. SQL Express does come with an installer merge module, so there shouldnt be an issue there.
|
|
|
|
|
Tommy4U wrote: Months ago, I started having some fun writting a POS (Point Of Sale) system
Ok, so far.
Tommy4U wrote: I decided to make some profit by sellling this software.
What? And you think that follows Best Practice for developing production software?
Tommy4U wrote: I am using VB
Ah, ok, that explains it, never mind.
led mike
|
|
|
|
|