Ticket #4170 (closed enhancement: fixed)
Move CI from Travis to GitHub Actions
| Reported by: | zaytsev | Owned by: | zaytsev | 
|---|---|---|---|
| Priority: | critical | Milestone: | 4.8.33 | 
| Component: | adm | Version: | master | 
| Keywords: | Cc: | ||
| Blocked By: | Blocking: | #3542, #3738, #4584, #4602 | |
| Branch state: | merged | Votes for changeset: | committed-master | 
Attachments
Change History
comment:3 Changed 3 years ago by zaytsev
- Milestone changed from 4.8.29 to 4.8.30
First step is done with the Transifex workflows...
comment:5 Changed 2 years ago by zaytsev
- Milestone changed from 4.8.30 to 4.8.31
Resurrected Travis first...
comment:6 Changed 21 months ago by zaytsev
- Milestone changed from 4.8.31 to 4.8.32
Still too much work, sadly :(
comment:8 Changed 17 months ago by zaytsev
- Owner set to zaytsev
- Status changed from new to accepted
- Milestone changed from Future Releases to 4.8.32
comment:11 Changed 12 months ago by zaytsev
Oh man, on Fedora in Docker the tests are still failing:
Running suite(s): lib/mcconfig
Running suite lib/mcconfig
../../../../tests/lib/mcconfig/config_string.c:169:P:Core:test_create_ini_file_paths:0: Passed
../../../../tests/lib/mcconfig/config_string.c:169:P:Core:test_create_ini_file_paths:1: Passed
**
ERROR:../../../../tests/lib/mcconfig/config_string.c:196:test_create_ini_file_paths_fn: assertion failed (actual_value == data->expected_value): ("not-exists" == " \t \364\305\323\324\317\327\317\305 \332\316\301\336\305\316\311\305 ")
Bail out! ERROR:../../../../tests/lib/mcconfig/config_string.c:196:test_create_ini_file_paths_fn: assertion failed (actual_value == data->expected_value): ("not-exists" == " \t \364\305\323\324\317\327\317\305 \332\316\301\336\305\316\311\305 ")
../../../../tests/lib/mcconfig/config_string.c:169:E:Core:test_create_ini_file_paths:2: (after this point) Received signal 6 (Aborted)
It seems that we'll never get it done :(
comment:12 follow-up: ↓ 13 Changed 12 months ago by zaytsev
I think I've managed to add CI on:
- Ubuntu (main system)
- macOS
- Fedora
- Alpine
https://github.com/MidnightCommander/mc/actions/runs/11417299454
Andrew, any wishes?
I'm thinking Solaris would be great if possible. Other systems like BSD would be interesting, but I don't have any experience, and would like to add CI as soon as possible, actually, so that you can check for warnings, and see if things build at all for platforms which we managed to bring into supported status... So I would rather postpone anything beyond that.
comment:13 in reply to: ↑ 12 Changed 12 months ago by andrew_b
comment:14 Changed 12 months ago by andrew_b
Branch: 4170_github_ci
Initial changeset:b2767bef4d0712d3d23a1a83801f6e9bb9bd26a3
comment:15 Changed 12 months ago by zaytsev
I think I've found a practical way to run Solaris on GitHub Actions, so I would also add that, because we've got so far with porting. I've also now have a real Solaris (very slow) on my laptop instead of Illumos. Unfortunately, it's not exactly the same as Illumos and there are still some problems to solve...
comment:16 Changed 12 months ago by zaytsev
- Branch state changed from no branch to on rework
Okay, I think problems are solved, also on Solaris:
https://github.com/MidnightCommander/mc/actions/runs/11426161958
Still need to remove / re-implement Travis stuff.
comment:17 Changed 12 months ago by andrew_b
use `tail -1`, not `tail -n 1`
Why? Why not the same for head?
comment:18 follow-up: ↓ 20 Changed 12 months ago by zaytsev
- Branch state changed from on rework to on review
I think I'm done - after a dozen of pushes, CI seems quite stable. Sources publishing is also re-implemented:
http://source.midnight-commander.org
Ready for review.
Why? Why not the same for head?
Because non-XPG4 version of tail fails if you call it as tail -n 1, but tail -1 works everywhere and is portable. However, non-XPG4 version of head accepts -n 1, apparently, because it was developed a bit later - so doesn't make sense to change it. Crazy, I know.
P.S. I can't thank mooffie enough for developing the extfs tests. Unfortunately, we don't have sample data for all scripts, but at least those that have sample data can be checked automatically now.
comment:19 Changed 12 months ago by zaytsev
Proof:
% ssh solaris                                        
Last login: Sun Oct 20 12:20:56 2024 from 192.168.64.1
Oracle Solaris 11.4.42.111.0                  Assembled December 2021
root@solaris:~# tail -n 1 .profile 
usage: tail [+/-[n][lbc][f]] [file]
       tail [+/-[n][l][r|f]] [file]
root@solaris:~# tail -1 .profile 
root@solaris:~# head -n 1 .profile 
#
root@solaris:~# head -1 .profile 
#     
root@solaris:~# /usr/xpg4/bin/tail -n 1 .profile 
    comment:20 in reply to: ↑ 18 Changed 12 months ago by andrew_b
Replying to zaytsev:
Why? Why not the same for head?
Because non-XPG4 version of tail fails if you call it as tail -n 1, but tail -1 works everywhere and is portable.
I think it should be written in the commit message.
comment:21 follow-up: ↓ 22 Changed 12 months ago by andrew_b
Travis sends a notification via e-mail if building fails. Can Github do that?
comment:22 in reply to: ↑ 21 Changed 12 months ago by zaytsev
Replying to andrew_b:
Travis sends a notification via e-mail if building fails. Can Github do that?
Well, Travis doesn't do it anymore since March, because it's broken again for unknown reasons and I can't even log in to see why it's broken (did the credits run out again?), because the login is broken.
But yes, GitHub can do that. It sends a mail to the committer if the build is broken. See attached screenshot. You can also make it do any actions you want, of course - for that you'll have to write more YAML code.
I think it should be written in the commit message.
OK, I've amended the commit message.
comment:23 Changed 12 months ago by zaytsev
- Blocking 4602 added
(In #4602) I think I saw some script to check for warnings. Maybe we could activate it in the CI.
comment:24 Changed 12 months ago by zaytsev
I'm added documentation listing to CI and fixed the warning.
comment:25 Changed 12 months ago by zaytsev
It seems that our hard work to fix tests and portability issues is finally paying off! I have just added FreeBSD to the CI, and didn't even have to fix anything, really:
https://github.com/MidnightCommander/mc/actions/runs/11442677163
And FreeBSD is an unexpectedly nice system to work with.
comment:26 Changed 12 months ago by zaytsev
Anything else to be done here (other than removing Travis from our organization)? I have rebased the branch again and cleaned up the commits.
I was able to --enable-werror almost everywhere expect for macOS because of the warnings coming from gnu tar stuff generated by clang. But at least we have now --enable-werror on clang from FreeBSD after all my fixes.
I think it would be good to merge this before any new branches are merged, so that they are tested.
comment:27 Changed 12 months ago by andrew_b
doc/man/pl/mc.1.in
-.I ftp://[!][użytkownik[:hasło]@]komputer[:port][zdalny katalog] +.I ftp://[!][użytkownik[:hasło]@]komputer[:port]/[zdalny-katalog]
+.I ftp://[!][użytkownik[:hasło]@]komputer[:port]/[zdalny\-katalog]
comment:28 Changed 12 months ago by zaytsev
Added a fixup, thanks! Sadly groff doesn't warn about it and you can only find this out if you change local glyph mappings :(
comment:29 Changed 12 months ago by andrew_b
- Votes for changeset set to andrew_b
- Branch state changed from on review to approved
comment:30 Changed 12 months ago by zaytsev
- Status changed from accepted to testing
- Votes for changeset changed from andrew_b to committed-master
- Resolution set to fixed
- Branch state changed from approved to merged
Merged to master as [494aeabe274cb6a64cd44241402c42111c153a47].
git log --oneline 4bd73a7de..494aeabe2
Fixed Transifex paths in 9e4e7e8a7fd495d0cb83166a0542736e8dc10ebf .
comment:32 Changed 10 months ago by zaytsev
I have fixed source site generation in [17c2a65cd517ab225a5fa9ff8d08b999fed498ab], which got broken due to action runner Ruby version upgrade. Andrew, you should have gotten an email that it got broken. I hope these mails are sent correctly. I do get them when I break the build in a branch. I saw the breakage on master by chance just by looking at the interface, because I wasn't the committer.


Update: I have migrated the CI from travis-ci.org to travis-ci.com - unfortunately, the 10k credits didn't last long. We have got a temporary grant of credits from Travis - hopefully this will last until I find time to migrate to GitHub? Actions.