add arguments to support customized working dir

This commit is contained in:
Casper Chang
2021-01-04 13:12:17 +08:00
parent 68f308d8ce
commit 45a6f05dde
6 changed files with 65 additions and 32 deletions

View File

@@ -1,5 +1,11 @@
# expect script for chromium init repo. # expect script for chromium init repo.
This script is inteted to deploy for daily build chromium OS This script is inteted to deploy for daily build chromium OS
Working directory is hard coding in `~/chrome/`. # usage
So please make sure you clone this repo into `~/chrome` directory. ```
$ ./main_cros_reposync_build.sh [user_password] [working_directory]"
```
# todo
1. add branch support
2. judge the working path, only remove last string if space

View File

@@ -1,9 +1,15 @@
#!/bin/bash #!/bin/bash
#
SCRIPT_DIR=${HOME}/chrome/daily_routine_repo # enter working directory
WORKING_DIR=${HOME}/chrome/dailyBuildToT #
# WORKING_DIR=/home/casperchang/chrome/ToT _working_dir_name=$1
_working_dir_name=${_working_dir_name::-1}
_mydir="$(pwd)"
_parentdir="$(dirname "$_mydir")"
_working_full_path="${_parentdir}/${_working_dir_name}"
cd ${_working_full_path}
echo "working path ${_working_full_path}"
cp -R ${SCRIPT_DIR}/local_manifests ${WORKING_DIR}/.repo cp -R ${SCRIPT_DIR}/local_manifests ${WORKING_DIR}/.repo
ls ${WORKING_DIR}/.repo ls ${WORKING_DIR}/.repo
ls ${WORKING_DIR}/.repo/local_manifests

View File

@@ -1,9 +1,12 @@
#!/bin/bash #!/bin/bash
#
# Create working directory
#
_working_dir_name=$1
_working_dir_name=${_working_dir_name::-1}
_working_full_path="${_parentdir}/${_working_dir_name}"
cd ${_working_full_path}
echo "GOTO: ${_working_full_path}"
SCRIPT_DIR=${HOME}/chrome/daily_routine_repo
WORKING_DIR=${HOME}/chrome/dailyBuildToT
# WORKING_DIR=/home/casperchang/chrome/ToT
cd ${WORKING_DIR}
echo 'cros_sdk --no-ns-pid' echo 'cros_sdk --no-ns-pid'
cros_sdk --no-ns-pid cros_sdk --no-ns-pid

View File

@@ -1,12 +1,20 @@
#!/bin/bash #!/bin/bash
# TODO: maybe to umount and remove old ToT? #
# Or `cros_sdk --delete` enough ? # Create working directory
# somehow there's a space char when expect argument
_working_dir_name=$1
_working_dir_name=${_working_dir_name::-1}
SCRIPT_DIR=${HOME}/chrome/daily_routine_repo _mydir="$(pwd)"
WORKING_DIR=${HOME}/chrome/dailyBuildToT _parentdir="$(dirname "$_mydir")"
# WORKING_DIR=/home/casperchang/chrome/ToT _working_full_path="${_parentdir}/${_working_dir_name}"
_working_full_path=${_working_full_path// /}
mkdir -p ${_working_full_path}
cd ${_working_full_path}
echo "INFO: Created new directory: ${_working_full_path}"
mkdir ${WORKING_DIR} #
cd ${WORKING_DIR} # Do repo init
#
repo init -u https://chromium.googlesource.com/chromiumos/manifest.git --repo-url https://chromium.googlesource.com/external/repo.git repo init -u https://chromium.googlesource.com/chromiumos/manifest.git --repo-url https://chromium.googlesource.com/external/repo.git

View File

@@ -1,11 +1,14 @@
#!/bin/bash #!/bin/bash
# TODO: maybe to umount and remove old ToT? #
# Or `cros_sdk --delete` enough ? # enter working directory
#
_working_dir_name=$1
_working_dir_name=${_working_dir_name::-1}
_mydir="$(pwd)"
_parentdir="$(dirname "$_mydir")"
_working_full_path="${_parentdir}/${_working_dir_name}"
cd ${_working_full_path}
echo "INFO: repo sync in dir ${_working_full_path}"
SCRIPT_DIR=${HOME}/chrome/daily_routine_repo
WORKING_DIR=${HOME}/chrome/dailyBuildToT
# WORKING_DIR=/home/casperchang/chrome/ToT
cd ${WORKING_DIR}
repo sync repo sync

View File

@@ -4,23 +4,30 @@
# 2. cp local_manifest folder to new directory's .repo/ # 2. cp local_manifest folder to new directory's .repo/
# 3. enter new directory and repo sync [expect] wait success # 3. enter new directory and repo sync [expect] wait success
# 4. cros_sdk --no-ns-pid to enter chroot [expect] enter password # 4. cros_sdk --no-ns-pid to enter chroot [expect] enter password
set user_password [lindex $argv 0]
set working_dir [lindex $argv 1]
set num_arg [llength $argv]
puts "INFO: Total: $num_arg argument(s)"
# set password [lindex $argv 0 ] # password if { ${num_arg} ne 2} {
# set build_image [lindex $argv 1 ] # 接收第2個引數,作為userid puts "ERROR: not enough argument passed"
puts "ERROR: usage: ./main_cros_reposync_build.sh {user_password} {working_directory}"
return 0
}
set timeout -1 set timeout -1
spawn ./cros_repoinit.sh spawn ./cros_repoinit.sh ${working_dir}
expect "repo has been initialized" expect "repo has been initialized"
spawn ./cros_cp_localmanifest.sh spawn ./cros_cp_localmanifest.sh ${working_dir}
expect "local_manifests" expect "local_manifests"
spawn ./cros_reposync.sh spawn ./cros_reposync.sh ${working_dir}
expect "repo sync has finished successfully" expect "repo sync has finished successfully"
spawn ./cros_enter_sdk.sh spawn ./cros_enter_sdk.sh
expect "password" expect "password"
send "casper\r" send "${user_password :: -1}\r"
expect "(cr)" expect "(cr)"
send "setup_board --board=volteer --profile=eldrid --force | tee daily_setup_board.log\r" send "setup_board --board=volteer --profile=eldrid --force | tee daily_setup_board.log\r"