aboutsummaryrefslogblamecommitdiff
path: root/test/segments/command_execution_time.spec
blob: b47d3fc9f3af1ea4f8b5fe4d4f926afd1261ebac (plain) (tree)
1
2
3
4
5
6
7
8
9








                                         


                                                                     
                                            
                                                                         
                                              




                               
                               

                                                                                  

 
                                                            
                                            
                                                            
                                                       




                               
                                  
 
                                                                                                 


                                                              
                                            
                                                            

                                                       
 
                                                                                                 
 
 
                                                            
                                            
                                                            

                                                       




                               
                                    
 
                                                                                                   

 
                                                              
                                            
                                                            
                                                       




                               
                                     
 
                                                                                               

 
                                                                                 
                                            
                                                            




                               
                                 
 
                                                                                                  


                                                                               
                                            
                                                            




                               
                                  
 
                                                                                                     

 
                     
#!/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() {
  local -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS
  POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=(custom_world command_execution_time)
  local POWERLEVEL9K_CUSTOM_WORLD='echo world'

  # Load Powerlevel9k
  source powerlevel9k.zsh-theme

  # Override payload
  local _P9K_COMMAND_DURATION=2

  assertEquals "%K{white} %F{black}world %k%F{white}%f " "$(build_left_prompt)"
}

function testCommandExecutionTimeThresholdCouldBeChanged() {
  local -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS
  POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=(command_execution_time)
  local POWERLEVEL9K_COMMAND_EXECUTION_TIME_THRESHOLD=1

  # Load Powerlevel9k
  source powerlevel9k.zsh-theme

  # Override payload
  local _P9K_COMMAND_DURATION=2.03

  assertEquals "%K{red} %F{yellow1%}Dur %f%F{yellow1}2.03 %k%F{red}%f " "$(build_left_prompt)"
}

function testCommandExecutionTimeThresholdCouldBeSetToZero() {
  local -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS
  POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=(command_execution_time)
  local POWERLEVEL9K_COMMAND_EXECUTION_TIME_THRESHOLD=0
  local _P9K_COMMAND_DURATION=0.03

  assertEquals "%K{red} %F{yellow1%}Dur %f%F{yellow1}0.03 %k%F{red}%f " "$(build_left_prompt)"
}

function testCommandExecutionTimePrecisionCouldBeChanged() {
  local -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS
  POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=(command_execution_time)
  local POWERLEVEL9K_COMMAND_EXECUTION_TIME_THRESHOLD=0
  local POWERLEVEL9K_COMMAND_EXECUTION_TIME_PRECISION=4

  # Load Powerlevel9k
  source powerlevel9k.zsh-theme

  # Override payload
  local _P9K_COMMAND_DURATION=0.0001

  assertEquals "%K{red} %F{yellow1%}Dur %f%F{yellow1}0.0001 %k%F{red}%f " "$(build_left_prompt)"
}

function testCommandExecutionTimePrecisionCouldBeSetToZero() {
  local -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS
  POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=(command_execution_time)
  local POWERLEVEL9K_COMMAND_EXECUTION_TIME_PRECISION=0

  # Load Powerlevel9k
  source powerlevel9k.zsh-theme

  # Override payload
  local _P9K_COMMAND_DURATION=23.5001

  assertEquals "%K{red} %F{yellow1%}Dur %f%F{yellow1}23 %k%F{red}%f " "$(build_left_prompt)"
}

function testCommandExecutionTimeIsFormattedHumandReadbleForMinuteLongCommand() {
  local -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS
  POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=(command_execution_time)

  # Load Powerlevel9k
  source powerlevel9k.zsh-theme

  # Override payload
  local _P9K_COMMAND_DURATION=180

  assertEquals "%K{red} %F{yellow1%}Dur %f%F{yellow1}03:00 %k%F{red}%f " "$(build_left_prompt)"
}

function testCommandExecutionTimeIsFormattedHumandReadbleForHourLongCommand() {
  local -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS
  POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=(command_execution_time)

  # Load Powerlevel9k
  source powerlevel9k.zsh-theme

  # Override payload
  local _P9K_COMMAND_DURATION=7200

  assertEquals "%K{red} %F{yellow1%}Dur %f%F{yellow1}02:00:00 %k%F{red}%f " "$(build_left_prompt)"
}

source shunit2/shunit2