aboutsummaryrefslogtreecommitdiff
path: root/test/segments/command_execution_time.spec
blob: 6d2d7ad99d1cddd0df75055f5c6c6009b95312d9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
#!/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{007} %F{000}world %k%F{007}%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{001} %F{226}Dur %F{226}2.03 %k%F{001}%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{001} %F{226}Dur %F{226}0.03 %k%F{001}%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{001} %F{226}Dur %F{226}0.0001 %k%F{001}%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{001} %F{226}Dur %F{226}23 %k%F{001}%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{001} %F{226}Dur %F{226}03:00 %k%F{001}%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{001} %F{226}Dur %F{226}02:00:00 %k%F{001}%f " "$(build_left_prompt)"
}

source shunit2/shunit2