- 
                Notifications
    You must be signed in to change notification settings 
- Fork 3
Fix test assumptions #47
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
base: main
Are you sure you want to change the base?
Conversation
| This strikes me as a weird way to go about this, how are we going to maintain this going forward? We're creating a weird sense of all green, when in fact we don't run the same tests on different systems. What happens if a future commit would make previously excluded tests pass again, wouldn't we want to know about that? My preference would be: 
 
 | 
| There are many things we can improve in future but right now we need something that works and is ready. Releasing an Alpha4 will happen but won't be a quick process. Also as we add features which are not in eXist-db we need to be able to switch tests on/off for that. The mechanism given to us by our testing framework (JUnit) for that purpose is Assumptions and that's how we use them. | 
| my point is that the mechanism for that given to us by the expath specs is <dependency processor="http://exist-db.org" semver-min="5.0.0" />
<dependency processor="http://evolved-binary.com" semver-min="1.0.0-ALPHA4" />and we're not using it, or that the mechanism provided by circleCi is command: 
                - 'verify -B -q -Dapi.port=8080 -Ddocker.db.image=existdb/existdb:latest'
                - 'verify -B -q -Dapi.port=8080 -Ddocker.db.image=existdb/existdb:5.2.0'
                - 'verify -B -q -Dapi.port=8080 -Ddocker.db.image=existdb/existdb:5.0.0'
                - 'verify -B -q -Ddocker.username=$FDB_NIGHTLY_DOCKER_USER -Ddocker.password=$FDB_NIGHTLY_DOCKER_PASS'do you really want to have the maintenance burden of checking the  
 ?? If we release new features in the api which are incompatible with older version we need to cut a new release here and declare the processor dependency. That works right now, for the future, takes a few minutes, and less lines of code the adjusting the test suite. | 
| I see where you are going, but I don't think either of those options address the requirement that we have. Let me try and see if I can explain an example... Given 4 features: fA, fB, fC, and fD: 
 We need to be able to only test those features (or aspects of features) for specific products and versions. As the tests are at the granularity of Java functions, we currently need to be able to enable/disable a Java test function depending on the test environment. The only way I know of to do this is with JUnit Assumptions. The options you suggested are too coarse for this use-case. I think for the time being, we should merge this PR and proceed. In future of course, I am hopeful that things will become much simpler and we may only support perhaps Elemental and FusionDB which will be much closer together in terms of API functions. If/when that happens we can revisit and revise this to a different approach. | 
2fe29eb    to
    5cf84fe      
    Compare
  
    There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
temporarily on hold
Not all tests and features are applicable to all versions of the server software.