* 写在前面
最近开发的一个项目希望实现这样一个功能。将本地项目创建脚手架置于远程服务器,而用户需要创建项目时,仅需要在提供的页面上填入一些项目基础配置并提交,后台便会根据选择自动化创建项目并 push 上仓库。咋看是个非常简单的需求,我们仅需要在用户发起创建请求时在后端调取 shell 脚本并可以实现这一系列的操作。然而目前项目创建脚手架不支持多参数传递,只能通过用户输入完成各参数传递的操作。于是抛出本文的主角:Expect,以实现一系列的自动化交互动作。
Expect 简介
expect 是一个免费的编程工具,用来实现自动的交互式任务,而无需人为干预。说白了,expect 就是一套用来实现自动交互功能的软件。在实际工作中,我们运行命令、脚本或程序时,这些命令、脚本或程序都需要从终端输入某些继续运行的指令,而这些输入都需要人为的手工进行。而利用 expect,则可以根据程序的提示,模拟标准输入提供给程序,从而实现自动化交互执行。这就是 expect!!!
Expect 命令
使用 expect 时,首先需要在文件顶部写入 #!/usr/bin/expect,已告知进程这是一个 expect 文件。而在脚本书写中基本离不开以下这「六」个命令。
spawn 启动新的进程
expect 用来等待一个进程的反馈,我们根据进程的反馈,再发送对应的交互命
send 发送需要交互的值,替代了用户手动输入内容
set 设置变量值
expect eof 自动化结束
interact 退出自动化,进入人工交互
Expect 语法
expect 使用的是 tcl 语法,详细教程可查阅 TCL 基本语法 – Tcl 教程这里提供几个简单的流程控制,一般来说已经够用了。
传参
expect 参数值存放在 $argv 中,比如取第一个参数就是 [lindex $argv 0],以此类推。
// 执行命令 xxx.sh mike 22 engineer
#!/usr/bin/expect
set name = [lindex $argv 0]
set age = [lindex $argv 1]
set job = [lindex $argv 2]
if/else
if {$a == ‘a’} {
set flag = 0
} else {
set flag = 1
}
expect ‘* 请输入 xxx 的值 *’
send $flag
循环匹配
一般来说 expect 匹配成功会会退出语句,而 exp_continue 表示循环匹配。匹配到改关键字后继续从头开始匹配。例如安装软件时需要输入多个 yes。
expect {
“*yes/no*” {
send “yes”
exp_continue
}
eof
{
send “eof”
}
}
栗子
未完待续