11 Commits

Author SHA1 Message Date
3241350fe7 test: added new entry in cron 2023-12-04 20:15:15 +11:00
88098e569c test: added debug messages, fix cron starter and remove spawner loop 2023-12-04 20:14:24 +11:00
0f822882f8 revert: need to split commit 2023-12-04 20:09:19 +11:00
838b884b8a test: debugging cron 2023-12-04 19:56:36 +11:00
03c0c0401e test: initial 2023-12-04 11:49:36 +11:00
d1c78f7b71 fix: logger usage 2023-12-04 11:23:08 +11:00
da71569517 Merge branch 'wip2' into multi-docker 2023-12-04 11:06:40 +11:00
190479d796 wip: alpine image 2023-12-03 12:56:26 +11:00
171c799a31 wip: cron shell script for testing 2023-12-02 15:54:41 +11:00
11dbe7d4f0 Merge branch 'wip2' into multi-docker 2023-12-02 14:53:02 +11:00
d26cc87713 wip: using different versions of rust images 2023-12-02 09:11:12 +11:00
17 changed files with 79 additions and 44 deletions

View File

@@ -5,10 +5,6 @@ edition = "2021"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[[bin]]
name = "wmexec"
path = "src/bin/util/exec.rs"
[[bin]]
name = "wmtest-helper-dummy"
path = "src/bin/test-helper/dummy.rs"

25
docker/alpine/Dockerfile Normal file
View File

@@ -0,0 +1,25 @@
FROM rust:alpine as builder
ADD . /root/wingmate
WORKDIR /root/wingmate
RUN apk add musl-dev && cargo clean && \
cargo build --release
FROM alpine
COPY --from=builder /root/wingmate/target/release/wingmate-rs /usr/local/bin/wingmate
COPY --from=builder /root/wingmate/target/release/wmtest-helper-dummy /usr/local/bin/wmtest-helper-dummy
COPY --from=builder /root/wingmate/target/release/wmtest-helper-spawner /usr/local/bin/wmtest-helper-spawner
COPY --from=builder /root/wingmate/target/release/wmtest-helper-log /usr/local/bin/wmtest-helper-log
ADD docker/alpine/etc/ /etc/
ADD docker/alpine/entry.sh /usr/local/bin/entry.sh
RUN chmod -R ugo+x /etc/wingmate && chmod +x /usr/local/bin/entry.sh && apk add tzdata && \
ln -sv /usr/share/zoneinfo/Australia/Sydney /etc/localtime
ENTRYPOINT [ "/usr/local/bin/entry.sh" ]
CMD [ "/usr/local/bin/wingmate" ]

7
docker/alpine/entry.sh Normal file
View File

@@ -0,0 +1,7 @@
#!/bin/sh
if [ $# -gt 0 ];then
exec "$@"
else
exec /usr/local/bin/wingmate
fi

View File

@@ -0,0 +1,4 @@
17 * * * * /etc/wingmate/crontab.d/cron1.sh
*/5 * * * * /etc/wingmate/crontab.d/cron2.sh
21,41 3,6,14,17,20,22 * * * /etc/wingmate/crontab.d/cron3.sh
* * * * * /etc/wingmate/crontab.d/cron4.sh

View File

@@ -0,0 +1,3 @@
#!/bin/sh
exec wmtest-helper-log /var/log/cron1.log "this cron runs every hour on minute 17"

View File

@@ -0,0 +1,3 @@
#!/bin/sh
exec wmtest-helper-log /var/log/cron2.log "this cron runs every hour on minute 5,10,15,20,25,30,35,40,45,50,55"

View File

@@ -0,0 +1,3 @@
#!/bin/sh
exec wmtest-helper-log /var/log/cron3.log "this cron runs based on this specification: 21,41 3,6,14,17,20,22 * * *"

View File

@@ -0,0 +1,3 @@
#!/bin/sh
exec wmtest-helper-log /var/log/cron4.log "this cron runs every minute"

View File

@@ -0,0 +1,4 @@
#!/bin/sh
export LOG_PATH=/var/log/one.log
exec /usr/local/bin/wmtest-helper-spawner 10

View File

@@ -0,0 +1,4 @@
#!/bin/sh
export LOG_PATH=/var/log/three.log
exec /usr/local/bin/wmtest-helper-spawner 13

View File

@@ -0,0 +1,4 @@
#!/bin/sh
export LOG_PATH=/var/log/two.log
exec /usr/local/bin/wmtest-helper-spawner 4

View File

@@ -0,0 +1,9 @@
FROM ubuntu:22.04
ADD target/debug/init /usr/local/bin/init
ADD docker/etc/ /etc/
RUN chmod ugo+x /etc/wingmate/services/one && chmod ugo+x /etc/wingmate/services/two.sh && \
chmod ugo-x /etc/wingmate/services/three.sh
CMD [ "/usr/local/bin/init" ]

View File

@@ -0,0 +1,3 @@
17 * * * * sleep 1
*/12 * * * * sleep 1
12,17,27 * * * * sleep 1

View File

@@ -0,0 +1 @@
you cannot run this file

View File

@@ -0,0 +1,3 @@
#!/bin/bash
exec sleep 1

View File

@@ -0,0 +1,3 @@
#!/bin/bash
exec sleep 1

View File

@@ -1,40 +0,0 @@
use std::env;
use std::path;
struct wmexec {
log: Option<Box<dyn AsRef<path::Path>>>,
}
impl wmexec {
fn new() -> wmexec {
wmexec {
log: None
}
}
fn log<P: AsRef<path::Path> + 'static>(&mut self, path: P) {
self.log = Some(Box::new(path));
}
}
fn main() -> Result<(), Box<dyn std::error::Error>> {
let args: Vec<String> = env::args().collect();
let mut start: usize = 0;
let mut skip_next = true;
'args: for i in 0..args.len() {
if skip_next {
skip_next = false;
continue 'args;
}
match args[i].as_str() {
"--" => {
start = i + 1;
break 'args;
},
_ => {}
}
}
Ok(())
}