Skip to content
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

Submitting some exercises results in Success no matter the code #79

Open
Rune-Christensen opened this issue Aug 23, 2022 · 10 comments
Open
Assignees
Labels
x:action/fix Fix an issue

Comments

@Rune-Christensen
Copy link
Contributor

I tried the Hello World and Collatz Conjecture exercises.
And both gives me succesful runs, without making the code that is needed for the tests to pass.
I then tried the Yacht exercise, and found that it works correctly.

So something is wrong in the setup of some of the exercises.

@0xE282B0
Copy link
Member

Did you use a STOP RUN.statement?

@Rune-Christensen
Copy link
Contributor Author

Hi @0xE282B0
Of course I do.
I know in simple programs, you do not necessarily need it, but when working with more complex programs, you would need it.
Also, the framework should be able to distinguish between, no test results returned, and succes.
I can also confirm, that goback and exit section also doesn't work with the framework as is.
Regards,
Rune

@0xE282B0
Copy link
Member

That's a known issue with cobol-check, the test returns with zero return code even if not all tests are executed.

@Rune-Christensen
Copy link
Contributor Author

But cobol-check also returns with zero return code, if some tests failed.
There must be a check after cobol-check runs, to determine if all tests passed or failed.

@0xE282B0
Copy link
Member

Right, cobol-check itself always returns with zero RC. There is a potential enhancement issue openmainframeproject/cobol-check#224.
As workaround, cobol-check only builds the test and we run it manually https://github.com/exercism/cobol/blob/main/exercises/practice/hello-world/test.sh#L16-L20.

There is no additional logic layer.

@Rune-Christensen
Copy link
Contributor Author

Ok, then I do not understand how you determine succes of the testsuite.
Just stating that it should not be possible to pass a test, by just adding the stop run statement to the program.

@0xE282B0
Copy link
Member

When a test fails the test program returns non-zero and the website shows that the exercise was not successful. But when you terminate the program during the test execution with a clean exit you pass the test.

Do you have any ideas on how to determine that all tests have been executed?

@Rune-Christensen
Copy link
Contributor Author

I have a couple of ideas.
The produced Cobol-check program could at runtime return 1 for a run without fails, and 4 for a run with fails. Then a zero return code would indicate that something is wrong.
You could look at the second to last line of the output, and determine if the line contains the string:
0 FAILED
If you use Cobol-check to run the test, it can examine the output, and return the result in other formats, and I believe that would fail, if the result is malformed. You could also easily parse the XML returned in those formats, to determine if there are failed tests.

@0xE282B0
Copy link
Member

A return code other than zero should always indicate an error.

I wasn't aware that cobol-check can output the results as XML. I tried to set test.results.format = xml and ran the tests with cobol-check but the testResults.xml is an empty file.
@Rune-Christensen do you have an example of how to get the results as XML output?

@Rune-Christensen
Copy link
Contributor Author

@0xE282B0 if you want to get the result as xml, you need to use cobol-check for compiling and running the test.
XML and HTML outputs are generated through postprocessing of the text output that cobol writes.

Perhaps Cobol check should be changed, so the generated cobol begins with setting return code 8. When the run is complete, the generated cobol should then set rc 4 if there are failed tests, and zero if no tests failed.
In that way, if the program exits before the run is complete, a return code of 8 is in effect.

@axtens axtens self-assigned this Apr 15, 2024
@axtens axtens added the x:action/fix Fix an issue label Apr 15, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
x:action/fix Fix an issue
Projects
None yet
Development

No branches or pull requests

4 participants
@axtens @0xE282B0 @Rune-Christensen and others