mirror of
https://github.com/wez/wezterm.git
synced 2024-12-22 12:51:31 +03:00
Ensure /run/sshd exists, explicitly set username in sshd fixture, add back use_privilege_mode no
This commit is contained in:
parent
d98a2cbbc2
commit
7d5c301c66
@ -13,7 +13,7 @@ task:
|
||||
- chmod +x /tmp/rustup.sh
|
||||
- RUSTUP_IO_THREADS=1 /tmp/rustup.sh -y -q
|
||||
- env PATH=$HOME/.cargo/bin:$PATH bash get-deps
|
||||
- chmod og-rw $HOME
|
||||
- mkdir -p /run/sshd
|
||||
test_script:
|
||||
- env PATH=$HOME/.cargo/bin:$PATH cargo build --all --release
|
||||
- env PATH=$HOME/.cargo/bin:$PATH cargo test --all --release
|
||||
|
3
.github/workflows/gen_centos7.yml
vendored
3
.github/workflows/gen_centos7.yml
vendored
@ -45,6 +45,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "yum install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "yum install -y openssh-server"
|
||||
|
5
.github/workflows/gen_centos7_continuous.yml
vendored
5
.github/workflows/gen_centos7_continuous.yml
vendored
@ -54,6 +54,11 @@ jobs:
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
yum install -y curl
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
mkdir -p /run/sshd
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: |
|
||||
|
3
.github/workflows/gen_centos7_tag.yml
vendored
3
.github/workflows/gen_centos7_tag.yml
vendored
@ -36,6 +36,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "yum install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "yum install -y openssh-server"
|
||||
|
3
.github/workflows/gen_centos8.yml
vendored
3
.github/workflows/gen_centos8.yml
vendored
@ -31,6 +31,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "yum install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "yum install -y openssh-server"
|
||||
|
5
.github/workflows/gen_centos8_continuous.yml
vendored
5
.github/workflows/gen_centos8_continuous.yml
vendored
@ -41,6 +41,11 @@ jobs:
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
yum install -y curl
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
mkdir -p /run/sshd
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: |
|
||||
|
3
.github/workflows/gen_centos8_tag.yml
vendored
3
.github/workflows/gen_centos8_tag.yml
vendored
@ -22,6 +22,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "yum install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "yum install -y openssh-server"
|
||||
|
3
.github/workflows/gen_debian10.3.yml
vendored
3
.github/workflows/gen_debian10.3.yml
vendored
@ -31,6 +31,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "apt-get install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "apt-get install -y openssh-server"
|
||||
|
@ -41,6 +41,11 @@ jobs:
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
apt-get install -y curl
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
mkdir -p /run/sshd
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: |
|
||||
|
3
.github/workflows/gen_debian10.3_tag.yml
vendored
3
.github/workflows/gen_debian10.3_tag.yml
vendored
@ -22,6 +22,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "apt-get install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "apt-get install -y openssh-server"
|
||||
|
3
.github/workflows/gen_debian11.yml
vendored
3
.github/workflows/gen_debian11.yml
vendored
@ -31,6 +31,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "apt-get install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "apt-get install -y openssh-server"
|
||||
|
@ -41,6 +41,11 @@ jobs:
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
apt-get install -y curl
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
mkdir -p /run/sshd
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: |
|
||||
|
3
.github/workflows/gen_debian11_tag.yml
vendored
3
.github/workflows/gen_debian11_tag.yml
vendored
@ -22,6 +22,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "apt-get install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "apt-get install -y openssh-server"
|
||||
|
3
.github/workflows/gen_debian9.12.yml
vendored
3
.github/workflows/gen_debian9.12.yml
vendored
@ -45,6 +45,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "apt-get install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "apt-get install -y openssh-server"
|
||||
|
@ -54,6 +54,11 @@ jobs:
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
apt-get install -y curl
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
mkdir -p /run/sshd
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: |
|
||||
|
3
.github/workflows/gen_debian9.12_tag.yml
vendored
3
.github/workflows/gen_debian9.12_tag.yml
vendored
@ -36,6 +36,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "apt-get install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "apt-get install -y openssh-server"
|
||||
|
3
.github/workflows/gen_fedora33.yml
vendored
3
.github/workflows/gen_fedora33.yml
vendored
@ -25,6 +25,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "yum install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "yum install -y openssh-server"
|
||||
|
@ -31,6 +31,11 @@ jobs:
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
yum install -y curl
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
mkdir -p /run/sshd
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: |
|
||||
|
3
.github/workflows/gen_fedora33_tag.yml
vendored
3
.github/workflows/gen_fedora33_tag.yml
vendored
@ -16,6 +16,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "yum install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "yum install -y openssh-server"
|
||||
|
3
.github/workflows/gen_fedora34.yml
vendored
3
.github/workflows/gen_fedora34.yml
vendored
@ -25,6 +25,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "yum install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "yum install -y openssh-server"
|
||||
|
@ -31,6 +31,11 @@ jobs:
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
yum install -y curl
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
mkdir -p /run/sshd
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: |
|
||||
|
3
.github/workflows/gen_fedora34_tag.yml
vendored
3
.github/workflows/gen_fedora34_tag.yml
vendored
@ -16,6 +16,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "yum install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "yum install -y openssh-server"
|
||||
|
3
.github/workflows/gen_ubuntu20.04.yml
vendored
3
.github/workflows/gen_ubuntu20.04.yml
vendored
@ -31,6 +31,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "apt-get install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "apt-get install -y openssh-server"
|
||||
|
@ -41,6 +41,11 @@ jobs:
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
apt-get install -y curl
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: |
|
||||
export BUILD_REASON=Schedule
|
||||
mkdir -p /run/sshd
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: |
|
||||
|
3
.github/workflows/gen_ubuntu20.04_tag.yml
vendored
3
.github/workflows/gen_ubuntu20.04_tag.yml
vendored
@ -22,6 +22,9 @@ jobs:
|
||||
- name: "Install curl"
|
||||
shell: bash
|
||||
run: "apt-get install -y curl"
|
||||
- name: "Ensure /run/sshd exists"
|
||||
shell: bash
|
||||
run: "mkdir -p /run/sshd"
|
||||
- name: "Install openssh-server"
|
||||
shell: bash
|
||||
run: "apt-get install -y openssh-server"
|
||||
|
11
Cargo.lock
generated
11
Cargo.lock
generated
@ -5382,6 +5382,7 @@ dependencies = [
|
||||
"structopt",
|
||||
"termwiz",
|
||||
"thiserror",
|
||||
"whoami",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
@ -5485,6 +5486,16 @@ dependencies = [
|
||||
"bitflags",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "whoami"
|
||||
version = "1.1.4"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "cabfe22aa4936611957e0b5ad9ed0472ac52b2bfb9aedac4a3f3a91a03bd1ff0"
|
||||
dependencies = [
|
||||
"wasm-bindgen",
|
||||
"web-sys",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "winapi"
|
||||
version = "0.2.8"
|
||||
|
@ -162,7 +162,10 @@ class Target(object):
|
||||
|
||||
def install_openssh_server(self):
|
||||
if self.uses_yum() or (self.uses_apt() and self.container):
|
||||
return self.install_system_package("openssh-server")
|
||||
return (
|
||||
[RunStep("Ensure /run/sshd exists", "mkdir -p /run/sshd")]
|
||||
+ self.install_system_package("openssh-server")
|
||||
)
|
||||
return []
|
||||
|
||||
def install_newer_compiler(self):
|
||||
|
@ -41,3 +41,4 @@ shell-words = "1.0"
|
||||
smol-potat = "1.1.2"
|
||||
structopt = "0.3"
|
||||
termwiz = { path = "../termwiz" }
|
||||
whoami = "1.1"
|
||||
|
@ -1,5 +1,5 @@
|
||||
use assert_fs::{prelude::*, TempDir};
|
||||
use once_cell::sync::OnceCell;
|
||||
use once_cell::sync::{Lazy, OnceCell};
|
||||
use rstest::*;
|
||||
use std::{
|
||||
collections::HashMap,
|
||||
@ -21,6 +21,8 @@ const BIN_PATH_STR: &str = "/usr/sbin/sshd";
|
||||
/// Port range to use when finding a port to bind to (using IANA guidance)
|
||||
const PORT_RANGE: (u16, u16) = (49152, 65535);
|
||||
|
||||
const USERNAME: Lazy<String> = Lazy::new(|| whoami::username());
|
||||
|
||||
pub struct SshKeygen;
|
||||
|
||||
impl SshKeygen {
|
||||
@ -92,6 +94,7 @@ impl Default for SshdConfig {
|
||||
let mut config = Self::new();
|
||||
|
||||
config.set_authentication_methods(vec!["publickey".to_string()]);
|
||||
config.set_use_privilege_separation(false);
|
||||
config.set_subsystem(true, true);
|
||||
config.set_use_pam(false);
|
||||
config.set_x11_forwarding(true);
|
||||
@ -400,6 +403,7 @@ pub async fn session(sshd: &'_ Sshd) -> Session {
|
||||
// generated identity file, and host file
|
||||
let mut config = config.for_host("localhost");
|
||||
config.insert("port".to_string(), port.to_string());
|
||||
config.insert("user".to_string(), USERNAME.to_string());
|
||||
config.insert("identitiesonly".to_string(), "yes".to_string());
|
||||
config.insert(
|
||||
"identityfile".to_string(),
|
||||
|
Loading…
Reference in New Issue
Block a user