-
-
Notifications
You must be signed in to change notification settings - Fork 161
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
Improve AppVeyor Build #505
base: main
Are you sure you want to change the base?
Conversation
5491c13
to
8656962
Compare
8656962
to
86adbe0
Compare
86adbe0
to
8fac1ee
Compare
This issue has been automatically marked as stale because it has not had recent activity. It will be closed in a week if no further activity occurs. |
8fac1ee
to
9722a55
Compare
Can we rebase/merge master into this? |
Yes, I'll do a rebase. |
.. maybe even split it up so at least the build runs with the correct ruby versions. |
099886e
to
da3a655
Compare
Specs are green 🎉. Now for the features 🚧 👷♂️ 👷♀️ 🏗️ |
Congratulations on reaching a milestone on this! Getting specs to green is a summit to enjoy. Next mountain will be possible to scale now that you’ve seen how high up you are. (The only way is up.) |
3c3b4d4
to
0bb789c
Compare
@mvz Was thinking of this branch, and how it makes the AppVeyor target list shorter - can THAT part be cherry-picked earlier than we fix all features for Windows support, too? |
@olleolleolle I suppose all of it can be merged (once I fix the Travis build), since passing specs is better than failing specs. |
@mvz Mind if I rebase and take a crack at this? |
@xtrasimplicity please go ahead. As far as I remember, the current status is that specs are succeeding and cukes are failing. The main reason for the failing cukes is that Windows won't accept executables that have names without extensions, so all the scenarios that create some |
Hey All, I have some spare time this weekend to work on getting Aruba's test suite to work on Windows, and I was thinking I'd create Windows-specific versions of the current Linux-specific tests. Given the current tests are used as documentation and I don't want to pollute the documentation with almost entirely-duplicated tests, I was thinking I might create a seperate folder under features/ for miscellaneous Windows-specific tests (that don't need to be included as documentation)? Take the following scenario, for example. I don't think we need to have the exact same scenario duplicated beneath it, using # features\01_getting_started_with_aruba\cleanup_working_directory.feature
Scenario: Clean up artifacts and pwd from a previous scenario
Given a file named "features/cleanup.feature" with:
"""
Feature: Check
Scenario: Check #1
Given a file named "file.txt" with "content"
And a directory named "dir.d"
Then a file named "file.txt" should exist
And a directory named "dir.d" should exist
When I cd to "dir.d"
And I run `pwd`
Then the output should match %r</tmp/aruba/dir.d$>
Scenario: Check #2
Then a file named "file.txt" should not exist
And a directory named "dir.d" should not exist
When I run `pwd`
Then the output should match %r</tmp/aruba$>
"""
When I run `cucumber`
Then the features should all pass For scenarios like the following, I would create a @requires-bash
Scenario: Bash Program run via bash
Given a file named "features/hello_aruba.feature" with:
"""
Feature: Getting Started With Aruba
Scenario: First Run of Command
Given a file named "cli.sh" with:
\"\"\"
echo "Hello, Aruba!"
\"\"\"
When I successfully run `bash ./cli.sh`
Then the output should contain:
\"\"\"
Hello, Aruba!
\"\"\"
"""
When I successfully run `cucumber`
Then the features should all pass So, ultimately, how should I handle features that we don't want to appear in Documentation? I'd rather not omit them completely, as our test coverage on Windows will continue to suffer. Any suggestions would be greatly appreciated. :) Thanks! @aslakhellesoy @olleolleolle @mvz -- Sorry for tagging all of you; just keen to get working on this as soon as I can. 👍 |
I see you found a solution :-). |
Yep, I've added it to the 'unpublished' directory and updated the |
I think this is the way to go. We can always move selected scenarios from |
@@ -6,8 +6,10 @@ | |||
include_context 'uses aruba API' | |||
|
|||
describe '#run_command' do | |||
let(:cmd) { 'ruby -ne "puts $_"' } |
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.
Windows doesn't have a command like cat
that accepts input via stdin
, prints it to stdout
and accepts piped input, so this is the best I've come up with but it feels a little hack-y. @mvz, do you happen to know of any better ways to tackle this? Can you see any issues with this implementation? Thanks heaps!
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.
Would something lets gets.chomp
work here. Via an input on stdin? Genuinely not sure, so ignore me if not useful.
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.
That almost works, but the process exits immediately afterwards. I can add a loop and trap an interrupt signal, but it's a fair bit more verbose. I've also found it doesn't quite function in the same way that cat
does. Thanks heaps for the suggestion, though. :)
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.
@xtrasimplicity I can't remember what the Windows-equivalent command was. type
, maybe? I kind of like your change because it's Just Ruby, but it may slow down tests on JRuby. Let's see how this goes for now.
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.
Thanks, @mvz. type
was almost perfect, from memory, but I don't think it handled SIGINT
signals (or the windows equivalent) correctly. I'll keep it as is for the moment and see how it goes. :)
|
||
# Convert \r\n to \n, if present in the output | ||
if last_command_output.include?("\r\n") | ||
allow(@aruba.last_command_started).to receive(:output).and_return(last_command_output.gsub("\r\n", "\n")) |
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.
Maybe better to either:
- make
have_output
behave properly in this case, - provide a special verision of
have_output
that ignores changes to line endings. - or change the expectation below depending on whethere we're on Windows.
I think I prefer the third option for now.
cf6f63a
to
4bfcab5
Compare
4bfcab5
to
71f65ee
Compare
71f65ee
to
785a9b1
Compare
785a9b1
to
2b174bc
Compare
2b174bc
to
2c9e012
Compare
8e431e2
to
db61ed5
Compare
db61ed5
to
dbe36bb
Compare
Are we just using GHA for everything now @mvz - We have a few Windows based builds on cucumber-ruby / rails and they all seem to run well |
@luke-hill yes, this is an old pull request and the PR name and branch name don't match the content anymore. I need to clean up all the branches and pull requests that aim to make the cucumber scenarios on Windows, but it's a bit of a mess. |
Summary
Work towards a green build on AppVeyor
Details
Get ffi to install on older RubiesThe FFI gem for mingw32 does not support 1.9.3.Motivation and Context
AppVeyor builds always fail and hence are worse than useless right now.
Types of changes