parser_test.go 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308
  1. package settings
  2. import (
  3. "testing"
  4. "github.com/stretchr/testify/assert"
  5. )
  6. func TestOption_Add(t *testing.T) {
  7. type fields struct {
  8. Args []string
  9. }
  10. type args struct {
  11. arg string
  12. }
  13. tests := []struct {
  14. name string
  15. fields fields
  16. args args
  17. want []string
  18. }{
  19. {name: "simple add", fields: fields{
  20. Args: []string{"a", "b"},
  21. }, args: args{
  22. arg: "c",
  23. }, want: []string{"a", "b", "c"}},
  24. {name: "null add", fields: fields{
  25. Args: nil,
  26. }, args: args{
  27. arg: "c",
  28. }, want: []string{"c"}},
  29. }
  30. for _, tt := range tests {
  31. t.Run(tt.name, func(t *testing.T) {
  32. o := &Option{
  33. Args: tt.fields.Args,
  34. }
  35. o.Add(tt.args.arg)
  36. assert.ElementsMatch(t, tt.want, o.Args)
  37. })
  38. }
  39. }
  40. func TestOption_Set(t *testing.T) {
  41. type fields struct {
  42. Args []string
  43. }
  44. type args struct {
  45. arg string
  46. }
  47. tests := []struct {
  48. name string
  49. fields fields
  50. args args
  51. want []string
  52. }{
  53. {name: "simple set", fields: fields{
  54. Args: []string{"a", "b"},
  55. }, args: args{
  56. arg: "c",
  57. }, want: []string{"c"}},
  58. {name: "null set", fields: fields{
  59. Args: nil,
  60. }, args: args{
  61. arg: "c",
  62. }, want: []string{"c"}},
  63. }
  64. for _, tt := range tests {
  65. t.Run(tt.name, func(t *testing.T) {
  66. o := &Option{
  67. Args: tt.fields.Args,
  68. }
  69. o.Set(tt.args.arg)
  70. assert.ElementsMatch(t, tt.want, o.Args)
  71. })
  72. }
  73. }
  74. func TestOption_First(t *testing.T) {
  75. type fields struct {
  76. Args []string
  77. }
  78. tests := []struct {
  79. name string
  80. fields fields
  81. want string
  82. }{
  83. {name: "simple first", fields: fields{
  84. Args: []string{"a", "b"},
  85. }, want: "a"},
  86. {name: "null first", fields: fields{
  87. Args: nil,
  88. }, want: ""},
  89. }
  90. for _, tt := range tests {
  91. t.Run(tt.name, func(t *testing.T) {
  92. o := &Option{
  93. Args: tt.fields.Args,
  94. }
  95. assert.Equal(t, tt.want, o.First())
  96. })
  97. }
  98. }
  99. func TestMakeArguments(t *testing.T) {
  100. args := MakeArguments()
  101. assert.NotNil(t, args)
  102. assert.Equal(t, "", args.Op)
  103. assert.Empty(t, args.Options)
  104. assert.Empty(t, args.Targets)
  105. }
  106. func TestArguments_CopyGlobal(t *testing.T) {
  107. type fields struct {
  108. Op string
  109. Options map[string]*Option
  110. Targets []string
  111. }
  112. tests := []struct {
  113. name string
  114. fields fields
  115. want *Arguments
  116. }{
  117. {name: "simple", fields: fields{
  118. Op: "Q",
  119. Options: map[string]*Option{
  120. "a": {}, "arch": {
  121. Global: true,
  122. Args: []string{"x86_x64"},
  123. }, "boo": {Global: true, Args: []string{"a", "b"}},
  124. },
  125. Targets: []string{"a", "b"},
  126. }, want: &Arguments{
  127. Op: "",
  128. Options: map[string]*Option{
  129. "arch": {
  130. Global: true,
  131. Args: []string{"x86_x64"},
  132. }, "boo": {Global: true, Args: []string{"a", "b"}},
  133. },
  134. Targets: []string{},
  135. }},
  136. }
  137. for _, tt := range tests {
  138. t.Run(tt.name, func(t *testing.T) {
  139. cmdArgs := &Arguments{
  140. Op: tt.fields.Op,
  141. Options: tt.fields.Options,
  142. Targets: tt.fields.Targets,
  143. }
  144. got := cmdArgs.CopyGlobal()
  145. assert.NotEqualValues(t, tt.fields.Options, got.Options)
  146. assert.NotEqualValues(t, tt.fields.Targets, got.Targets)
  147. assert.NotEqual(t, tt.fields.Op, got.Op)
  148. assert.Equal(t, tt.want, got)
  149. })
  150. }
  151. }
  152. func TestArguments_Copy(t *testing.T) {
  153. type fields struct {
  154. Op string
  155. Options map[string]*Option
  156. Targets []string
  157. }
  158. tests := []struct {
  159. name string
  160. fields fields
  161. want *Arguments
  162. }{
  163. {name: "simple", fields: fields{
  164. Op: "Q",
  165. Options: map[string]*Option{
  166. "a": {}, "arch": {
  167. Args: []string{"x86_x64"}, Global: true,
  168. }, "boo": {Args: []string{"a", "b"}, Global: true},
  169. },
  170. Targets: []string{"a", "b"},
  171. }, want: &Arguments{
  172. Op: "Q",
  173. Options: map[string]*Option{
  174. "a": {}, "arch": {
  175. Global: true,
  176. Args: []string{"x86_x64"},
  177. }, "boo": {Args: []string{"a", "b"}, Global: true},
  178. },
  179. Targets: []string{"a", "b"},
  180. }},
  181. }
  182. for _, tt := range tests {
  183. t.Run(tt.name, func(t *testing.T) {
  184. cmdArgs := &Arguments{
  185. Op: tt.fields.Op,
  186. Options: tt.fields.Options,
  187. Targets: tt.fields.Targets,
  188. }
  189. got := cmdArgs.Copy()
  190. assert.Equal(t, cmdArgs, got)
  191. assert.Equal(t, tt.want, got)
  192. })
  193. }
  194. }
  195. func TestArguments_DelArg(t *testing.T) {
  196. args := MakeArguments()
  197. args.addParam("arch", "arg")
  198. args.addParam("ask", "arg")
  199. args.DelArg("arch", "ask")
  200. assert.Empty(t, args.Options)
  201. }
  202. func TestArguments_FormatArgs(t *testing.T) {
  203. type fields struct {
  204. Op string
  205. Options map[string]*Option
  206. Targets []string
  207. }
  208. tests := []struct {
  209. name string
  210. fields fields
  211. wantArgs []string
  212. }{
  213. {name: "simple", fields: fields{
  214. Op: "S",
  215. Options: map[string]*Option{},
  216. Targets: []string{"yay", "yay-bin", "yay-git"},
  217. }, wantArgs: []string{"-S"}},
  218. {name: "only global", fields: fields{
  219. Op: "Y",
  220. Options: map[string]*Option{"noconfirm": {Global: true, Args: []string{""}}},
  221. Targets: []string{"yay", "yay-bin", "yay-git"},
  222. }, wantArgs: []string{"-Y"}},
  223. {name: "options single", fields: fields{
  224. Op: "Y",
  225. Options: map[string]*Option{"overwrite": {Args: []string{"/tmp/a"}}, "useask": {Args: []string{""}}},
  226. Targets: []string{},
  227. }, wantArgs: []string{"-Y", "--overwrite", "/tmp/a", "--useask"}},
  228. {name: "options doubles", fields: fields{
  229. Op: "Y",
  230. Options: map[string]*Option{"overwrite": {Args: []string{"/tmp/a", "/tmp/b", "/tmp/c"}}, "needed": {Args: []string{""}}},
  231. Targets: []string{},
  232. }, wantArgs: []string{"-Y", "--overwrite", "/tmp/a", "--overwrite", "/tmp/b", "--overwrite", "/tmp/c", "--needed"}},
  233. }
  234. for _, tt := range tests {
  235. t.Run(tt.name, func(t *testing.T) {
  236. cmdArgs := &Arguments{
  237. Op: tt.fields.Op,
  238. Options: tt.fields.Options,
  239. Targets: tt.fields.Targets,
  240. }
  241. gotArgs := cmdArgs.FormatArgs()
  242. assert.ElementsMatch(t, gotArgs, tt.wantArgs)
  243. })
  244. }
  245. }
  246. func TestArguments_FormatGlobalArgs(t *testing.T) {
  247. type fields struct {
  248. Op string
  249. Options map[string]*Option
  250. Targets []string
  251. }
  252. tests := []struct {
  253. name string
  254. fields fields
  255. wantArgs []string
  256. }{
  257. {name: "simple", fields: fields{
  258. Op: "S",
  259. Options: map[string]*Option{"dbpath": {Global: true, Args: []string{"/tmp/a", "/tmp/b"}}},
  260. Targets: []string{"yay", "yay-bin", "yay-git"},
  261. }, wantArgs: []string{"--dbpath", "/tmp/a", "--dbpath", "/tmp/b"}},
  262. {name: "only global", fields: fields{
  263. Op: "Y",
  264. Options: map[string]*Option{"noconfirm": {Global: true, Args: []string{""}}},
  265. Targets: []string{"yay", "yay-bin", "yay-git"},
  266. }, wantArgs: []string{"--noconfirm"}},
  267. {name: "options single", fields: fields{
  268. Op: "Y",
  269. Options: map[string]*Option{"overwrite": {Args: []string{"/tmp/a"}}, "useask": {Args: []string{""}}},
  270. Targets: []string{},
  271. }, wantArgs: []string(nil)},
  272. {name: "options doubles", fields: fields{
  273. Op: "Y",
  274. Options: map[string]*Option{"overwrite": {Args: []string{"/tmp/a", "/tmp/b", "/tmp/c"}}, "needed": {Args: []string{""}}},
  275. Targets: []string{},
  276. }, wantArgs: []string(nil)},
  277. }
  278. for _, tt := range tests {
  279. t.Run(tt.name, func(t *testing.T) {
  280. cmdArgs := &Arguments{
  281. Op: tt.fields.Op,
  282. Options: tt.fields.Options,
  283. Targets: tt.fields.Targets,
  284. }
  285. gotArgs := cmdArgs.FormatGlobals()
  286. assert.ElementsMatch(t, tt.wantArgs, gotArgs)
  287. })
  288. }
  289. }
  290. func Test_isArg(t *testing.T) {
  291. got := isArg("zorg")
  292. assert.False(t, got)
  293. got = isArg("dbpath")
  294. assert.True(t, got)
  295. }