2017-02-14 00:25:34 +00:00
|
|
|
#!/usr/bin/env zsh
|
|
|
|
#vim:ft=zsh ts=2 sw=2 sts=2 et fenc=utf-8
|
|
|
|
|
|
|
|
# Required for shunit2 to run correctly
|
|
|
|
setopt shwordsplit
|
|
|
|
SHUNIT_PARENT=$0
|
|
|
|
|
|
|
|
function setUp() {
|
|
|
|
export TERM="xterm-256color"
|
|
|
|
}
|
|
|
|
|
|
|
|
function testCommandExecutionTimeIsNotShownIfTimeIsBelowThreshold() {
|
2018-07-24 14:24:33 +00:00
|
|
|
local -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS
|
2017-02-14 00:25:34 +00:00
|
|
|
POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=(custom_world command_execution_time)
|
2018-07-24 14:24:33 +00:00
|
|
|
local POWERLEVEL9K_CUSTOM_WORLD='echo world'
|
2018-07-25 05:52:06 +00:00
|
|
|
|
|
|
|
# Load Powerlevel9k
|
|
|
|
source powerlevel9k.zsh-theme
|
|
|
|
|
|
|
|
# Override payload
|
2018-07-24 14:24:33 +00:00
|
|
|
local _P9K_COMMAND_DURATION=2
|
2017-02-14 00:25:34 +00:00
|
|
|
|
2018-08-07 23:54:55 +00:00
|
|
|
assertEquals "%K{015} %F{000}world %k%F{015}%f " "$(build_left_prompt)"
|
2017-02-14 00:25:34 +00:00
|
|
|
}
|
|
|
|
|
2017-02-14 20:32:41 +00:00
|
|
|
function testCommandExecutionTimeThresholdCouldBeChanged() {
|
2018-07-24 14:24:33 +00:00
|
|
|
local -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS
|
2017-02-14 20:32:41 +00:00
|
|
|
POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=(command_execution_time)
|
2018-07-24 14:24:33 +00:00
|
|
|
local POWERLEVEL9K_COMMAND_EXECUTION_TIME_THRESHOLD=1
|
2018-07-25 05:52:06 +00:00
|
|
|
|
|
|
|
# Load Powerlevel9k
|
|
|
|
source powerlevel9k.zsh-theme
|
|
|
|
|
|
|
|
# Override payload
|
2018-07-24 14:24:33 +00:00
|
|
|
local _P9K_COMMAND_DURATION=2.03
|
2017-02-14 20:32:41 +00:00
|
|
|
|
2018-08-08 22:28:50 +00:00
|
|
|
assertEquals "%K{009} %F{226}Dur %f%F{226}2.03 %k%F{009}%f " "$(build_left_prompt)"
|
2017-02-14 20:32:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function testCommandExecutionTimeThresholdCouldBeSetToZero() {
|
2018-07-24 14:24:33 +00:00
|
|
|
local -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS
|
2017-02-14 20:32:41 +00:00
|
|
|
POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=(command_execution_time)
|
2018-07-24 14:24:33 +00:00
|
|
|
local POWERLEVEL9K_COMMAND_EXECUTION_TIME_THRESHOLD=0
|
|
|
|
local _P9K_COMMAND_DURATION=0.03
|
2017-02-14 20:32:41 +00:00
|
|
|
|
2018-08-08 21:47:01 +00:00
|
|
|
assertEquals "%K{009} %F{226}Dur %f%F{226}0.03 %k%F{009}%f " "$(build_left_prompt)"
|
2017-02-14 20:32:41 +00:00
|
|
|
}
|
2017-02-14 00:25:34 +00:00
|
|
|
|
2017-02-14 20:32:41 +00:00
|
|
|
function testCommandExecutionTimePrecisionCouldBeChanged() {
|
2018-07-24 14:24:33 +00:00
|
|
|
local -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS
|
2017-02-14 20:32:41 +00:00
|
|
|
POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=(command_execution_time)
|
2018-07-24 14:24:33 +00:00
|
|
|
local POWERLEVEL9K_COMMAND_EXECUTION_TIME_THRESHOLD=0
|
|
|
|
local POWERLEVEL9K_COMMAND_EXECUTION_TIME_PRECISION=4
|
2018-07-25 05:52:06 +00:00
|
|
|
|
|
|
|
# Load Powerlevel9k
|
|
|
|
source powerlevel9k.zsh-theme
|
|
|
|
|
|
|
|
# Override payload
|
2018-07-24 14:24:33 +00:00
|
|
|
local _P9K_COMMAND_DURATION=0.0001
|
2017-02-14 20:32:41 +00:00
|
|
|
|
2018-08-08 22:28:50 +00:00
|
|
|
assertEquals "%K{009} %F{226}Dur %f%F{226}0.0001 %k%F{009}%f " "$(build_left_prompt)"
|
2017-02-14 00:25:34 +00:00
|
|
|
}
|
|
|
|
|
2017-02-14 20:32:41 +00:00
|
|
|
function testCommandExecutionTimePrecisionCouldBeSetToZero() {
|
2018-07-24 14:24:33 +00:00
|
|
|
local -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS
|
2017-02-14 20:32:41 +00:00
|
|
|
POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=(command_execution_time)
|
2018-07-24 14:24:33 +00:00
|
|
|
local POWERLEVEL9K_COMMAND_EXECUTION_TIME_PRECISION=0
|
2018-07-25 05:52:06 +00:00
|
|
|
|
|
|
|
# Load Powerlevel9k
|
|
|
|
source powerlevel9k.zsh-theme
|
|
|
|
|
|
|
|
# Override payload
|
2018-07-24 14:24:33 +00:00
|
|
|
local _P9K_COMMAND_DURATION=23.5001
|
2017-02-14 20:32:41 +00:00
|
|
|
|
2018-08-08 22:28:50 +00:00
|
|
|
assertEquals "%K{009} %F{226}Dur %f%F{226}23 %k%F{009}%f " "$(build_left_prompt)"
|
2017-02-14 20:32:41 +00:00
|
|
|
}
|
|
|
|
|
2017-02-14 00:25:34 +00:00
|
|
|
function testCommandExecutionTimeIsFormattedHumandReadbleForMinuteLongCommand() {
|
2018-07-24 14:24:33 +00:00
|
|
|
local -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS
|
2017-02-14 20:32:41 +00:00
|
|
|
POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=(command_execution_time)
|
2018-07-25 05:52:06 +00:00
|
|
|
|
|
|
|
# Load Powerlevel9k
|
|
|
|
source powerlevel9k.zsh-theme
|
|
|
|
|
|
|
|
# Override payload
|
2018-07-24 14:24:33 +00:00
|
|
|
local _P9K_COMMAND_DURATION=180
|
2017-02-14 00:25:34 +00:00
|
|
|
|
2018-08-08 22:28:50 +00:00
|
|
|
assertEquals "%K{009} %F{226}Dur %f%F{226}03:00 %k%F{009}%f " "$(build_left_prompt)"
|
2017-02-14 00:25:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function testCommandExecutionTimeIsFormattedHumandReadbleForHourLongCommand() {
|
2018-07-24 14:24:33 +00:00
|
|
|
local -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS
|
2017-02-14 20:32:41 +00:00
|
|
|
POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=(command_execution_time)
|
2018-07-25 05:52:06 +00:00
|
|
|
|
|
|
|
# Load Powerlevel9k
|
|
|
|
source powerlevel9k.zsh-theme
|
|
|
|
|
|
|
|
# Override payload
|
2018-07-24 14:24:33 +00:00
|
|
|
local _P9K_COMMAND_DURATION=7200
|
2017-02-14 00:25:34 +00:00
|
|
|
|
2018-08-08 22:28:50 +00:00
|
|
|
assertEquals "%K{009} %F{226}Dur %f%F{226}02:00:00 %k%F{009}%f " "$(build_left_prompt)"
|
2017-02-14 00:25:34 +00:00
|
|
|
}
|
|
|
|
|
2018-08-04 15:34:52 +00:00
|
|
|
source shunit2/shunit2
|