-
Notifications
You must be signed in to change notification settings - Fork 11
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Thread safety and Possible race conditions #27
Comments
We worked out a thread safety bug in #17 so make sure you are using the latest version. Can you create a test case where you run your code in parallel and try to spam it to see if you get any race conditions? |
Hey MadsKirkFoged, Thanks for working on the SharpFluids bit with me. I know I should be doing this so it makes it easier for you to fix. I've been using XUnit to unit test my new code libraries. And it is depdendent on EngineeringUnits, SharpFluids So it could be the spiceSharp Code that's not thread safe, or it could be yours? I don't know. And the exceptions are very hard to catch... But it seems everytime there is an exception, it's thrown by the EngineeringUnits package. Anyhow, i don't want to let you do more work than you need to. If i am able to pinpoint the case and run XUnit tests, I'll find it for you and write the code here. It's like weird, the moment i add features in my code which increase calculation time, all of a sudden i don't see the exceptions being thrown anymore. |
Im pretty sure the If you have a test that fails that is not using SharpFluids, that would be interesting to know about |
Okay sure, I'll let you know if anything crops up So sad though, i was intending to use sharpfluids for parallel computation (ahhhhh, #sadface) But as you said, coolprop dlls are not natively threadsafe Just inserting this here in case anyone else is reading the thread Based on these though, I've seen the use of AbstractState in C++ which helps achieve threadsafety Basically for anyone else reading abstract classes are C++ version's of interfaces. (C# has abstract classes also, but interfaces are distinct) This means one has got to move into coolprop via C++, code and compile a thread safe version of the library, and then generate the dlls. Yikes I might revisit this if i really need the speed, I hope i don't =( This is such a challenging issue lol. But again okay, i'll let you know if anything. I'm just thinking out loud here. |
Hello, thanks for providing such a wonderful piece of software.
Ive been writing code based on your modules and for some reason when i use xunit, there happens to be unrepeatable wrong unit exceptions which come. It means like once every twenty or thirty test runs, a wrong unit exception comes up.
When i rerun the tests, it disaappears and the tests pass.
It's about 200+ tests, and i strongly suspect it's because xunit does things in parallel, and also because some classes use static operators eg, addition and subtraction.
I strongly suspect a race condition as several classes or test cases are accessing static operators at the same time. And therefore it's not really thread safe.
Were there any of such cases before?
And what are some possible fixes we can work towards?
Edit: I'll also be checking in case my code (or what i'm building off - spicesharp) isn't thread safe. But tbh i have never used static methods in my code and all the exceptions and errors i've gotten were from the EngineeringUnits package tho.
The text was updated successfully, but these errors were encountered: