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

core: add ExecXYZEx= bus hook ups to all exec command properties #13369

Merged
merged 1 commit into from
Sep 17, 2019

Conversation

anitazha
Copy link
Member

The "Ex" variant was originally only added for ExecStartXYZ= but it makes
sense to have feature parity for the rest of the exec command properties
as well (e.g. ExecReload=, ExecStop=, etc).

@keszybz
Copy link
Member

keszybz commented Aug 22, 2019

Hmm, could we have some test that does what it is supposed to do? Maybe somewhere in the test/TEST-* ? It's easy to make a typo in stuff like this, so we should have at least a smoke test that makes a pass through the code.

Copy link
Member

@mrc0mmand mrc0mmand left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I agree with @keszybz that having a test for this would be great :-)

@@ -5534,16 +5534,22 @@ static int show_one(
{ "IPEgressBytes", "t", NULL, offsetof(UnitStatusInfo, ip_egress_bytes) },
{ "IOReadBytes", "t", NULL, offsetof(UnitStatusInfo, io_read_bytes) },
{ "IOWriteBytes", "t", NULL, offsetof(UnitStatusInfo, io_write_bytes) },
{ "ExecCondition", "a(sasbttttuii)", map_exec, 0 },
{ "ExecCondition", "a(sasasttttuii)", map_exec, 0 },
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Shouldn't this be ExecConditionEx?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Herp derp. Yes.

@anitazha
Copy link
Member Author

I've added new tests and fixed the copy pasta. PTAL.

@keszybz
Copy link
Member

keszybz commented Sep 17, 2019

semaphoreci simply timed out during build. I'll restart it.

bionic-arm64 fails:

ExecReload={ path=/bin/echo ; argv[]=/bin/echo ${5_five_ex} ; ignore_errors=no ; start_time=[n/a] ; stop_time=[n/a] ; pid=0 ; code=(null) ; status=0/0 }
Sent message type=method_return sender=org.freedesktop.systemd1 destination=n/a path=n/a interface=n/a member=n/a cookie=1 reply_cookie=1 signature=a{sv} error-name=n/a error-message=n/a
Bus private-bus-connection: changing state RUNNING → CLOSING
Bus private-bus-connection: changing state CLOSING → CLOSED
Got disconnect on private connection.
+ grep -F 'path=/bin/echo ; argv[]=/bin/echo ${5_five_ex} ; flags=no-env-expand'
+ systemctl show -p ExecReloadEx 5_five_ex
Bus bus-api-system: changing state AUTHENTICATING → HELLO
Sent message type=method_call sender=n/a destination=org.freedesktop.DBus path=/org/freedesktop/DBus interface=org.freedesktop.DBus member=Hello cookie=1 reply_cookie=0 signature=n/a error-name=n/a erro>
Sent message type=method_call sender=n/a destination=org.freedesktop.DBus path=/org/freedesktop/DBus interface=org.freedesktop.DBus member=AddMatch cookie=2 reply_cookie=0 signature=s error-name=n/a err>
Sent message type=method_call sender=n/a destination=org.freedesktop.DBus path=/org/freedesktop/DBus interface=org.freedesktop.DBus member=GetNameOwner cookie=3 reply_cookie=0 signature=s error-name=n/a>
Sent message type=method_call sender=n/a destination=org.freedesktop.DBus path=/org/freedesktop/DBus interface=org.freedesktop.DBus member=AddMatch cookie=4 reply_cookie=0 signature=s error-name=n/a err>
Sent message type=method_call sender=n/a destination=org.freedesktop.DBus path=/org/freedesktop/DBus interface=org.freedesktop.DBus member=RequestName cookie=5 reply_cookie=0 signature=su error-name=n/a>
Got message type=method_return sender=org.freedesktop.DBus destination=:1.1 path=n/a interface=n/a member=n/a cookie=1 reply_cookie=1 signature=s error-name=n/a error-message=n/a
Bus bus-api-system: changing state HELLO → RUNNING
Sent message type=method_call sender=n/a destination=org.freedesktop.DBus path=/org/freedesktop/DBus interface=org.freedesktop.DBus member=ListNames cookie=6 reply_cookie=0 signature=n/a error-name=n/a >
Got message type=method_return sender=org.freedesktop.DBus destination=:1.1 path=n/a interface=n/a member=n/a cookie=8 reply_cookie=6 signature=as error-name=n/a error-message=n/a
Sent message type=method_call sender=n/a destination=org.freedesktop.DBus path=/org/freedesktop/DBus interface=org.freedesktop.DBus member=GetNameOwner cookie=7 reply_cookie=0 signature=s error-name=n/a>
Got message type=method_return sender=org.freedesktop.DBus destination=:1.1 path=n/a interface=n/a member=n/a cookie=9 reply_cookie=7 signature=s error-name=n/a error-message=n/a
systemd-logind.service: D-Bus name org.freedesktop.login1 now registered by :1.0
systemd-logind.service: Changed start -> running
systemd-logind.service: Job 58 systemd-logind.service/start finished, result=done
[  OK  ] Started Login Service.
systemd-journald.service: Got notification message from PID 16 (FDSTORE=1)
systemd-journald.service: Added fd 18 (n/a) to fd store.
Bus private-bus-connection: changing state UNSET → OPENING
Bus private-bus-connection: changing state OPENING → AUTHENTICATING
Accepted new private connection.
Bus private-bus-connection: changing state AUTHENTICATING → RUNNING
Got message type=method_call sender=n/a destination=org.freedesktop.systemd1 path=/org/freedesktop/systemd1/unit/_35_5ffive_5fex_2eservice interface=org.freedesktop.DBus.Properties member=GetAll cookie=>
Sent message type=method_return sender=org.freedesktop.systemd1 destination=n/a path=n/a interface=n/a member=n/a cookie=1 reply_cookie=1 signature=a{sv} error-name=n/a error-message=n/a
Received SIGCHLD from PID 28 (testsuite.sh).
Child 28 (testsuite.sh) died (code=exited, status=2/INVALIDARGUMENT)
testsuite.service: Failed to read oom_kill field of memory.events cgroup attribute: No such file or directory
testsuite.service: Child 28 belongs to testsuite.service.
testsuite.service: Main process exited, code=exited, status=2/INVALIDARGUMENT
testsuite.service: Failed with result 'exit-code'.

It seems that ExecReloadEx is somehow wrong...

@keszybz
Copy link
Member

keszybz commented Sep 17, 2019

This needs a rebase because TEST-37 is already taken :(

@mrc0mmand
Copy link
Member

Even my PR (#13300) needs a post-merge fix as it collides with the other TEST-37 test case. However, I'll wait with the fix until this PR is resolved, as the number here should be bumped to 38, or even 39, due to TEST-37-FREEZER from #13512, which needs to be bumped as well :-)

@keszybz
Copy link
Member

keszybz commented Sep 17, 2019

Oh. I think we need some better way of assigning those numbers.

@keszybz
Copy link
Member

keszybz commented Sep 17, 2019

I run the test on arm64 for a while in a loop, and it succeeds without issue. Dunno, maybe let's treat this is a fluke. I don't see why arm64 would behave any different here. So please rename the test to TEST-40-… and we can merge.

The "Ex" variant was originally only added for ExecStartXYZ= but it makes
sense to have feature parity for the rest of the exec command properties
as well (e.g. ExecReload=, ExecStop=, etc).
@anitazha
Copy link
Member Author

Bumped test number to 40

@keszybz keszybz added good-to-merge/waiting-for-ci 👍 PR is good to merge, but CI hasn't passed at time of review. Please merge if you see CI has passed and removed needs-rebase labels Sep 17, 2019
@mrc0mmand mrc0mmand merged commit 898fc00 into systemd:master Sep 17, 2019
facebook-github-bot pushed a commit to facebookarchive/rpm-backports that referenced this pull request Sep 27, 2019
Summary:
New upstream release, plus a backport of
systemd/systemd#13369

Reviewed By: anitazha

Differential Revision: D17631247

fbshipit-source-id: e21450480a66af1a2e28dbe2a5612f3ddf62d4d8
@anitazha anitazha deleted the more_ex branch October 4, 2019 18:58
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
good-to-merge/waiting-for-ci 👍 PR is good to merge, but CI hasn't passed at time of review. Please merge if you see CI has passed pid1
Development

Successfully merging this pull request may close these issues.

4 participants