format_test.go 54 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483
  1. /*
  2. * Copyright (c) 2013 Dave Collins <dave@davec.name>
  3. *
  4. * Permission to use, copy, modify, and distribute this software for any
  5. * purpose with or without fee is hereby granted, provided that the above
  6. * copyright notice and this permission notice appear in all copies.
  7. *
  8. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  9. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  10. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
  11. * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  12. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  13. * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  14. * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. /*
  17. Test Summary:
  18. NOTE: For each test, a nil pointer, a single pointer and double pointer to the
  19. base test element are also tested to ensure proper indirection across all types.
  20. - Max int8, int16, int32, int64, int
  21. - Max uint8, uint16, uint32, uint64, uint
  22. - Boolean true and false
  23. - Standard complex64 and complex128
  24. - Array containing standard ints
  25. - Array containing type with custom formatter on pointer receiver only
  26. - Array containing interfaces
  27. - Slice containing standard float32 values
  28. - Slice containing type with custom formatter on pointer receiver only
  29. - Slice containing interfaces
  30. - Nil slice
  31. - Standard string
  32. - Nil interface
  33. - Sub-interface
  34. - Map with string keys and int vals
  35. - Map with custom formatter type on pointer receiver only keys and vals
  36. - Map with interface keys and values
  37. - Map with nil interface value
  38. - Struct with primitives
  39. - Struct that contains another struct
  40. - Struct that contains custom type with Stringer pointer interface via both
  41. exported and unexported fields
  42. - Struct that contains embedded struct and field to same struct
  43. - Uintptr to 0 (null pointer)
  44. - Uintptr address of real variable
  45. - Unsafe.Pointer to 0 (null pointer)
  46. - Unsafe.Pointer to address of real variable
  47. - Nil channel
  48. - Standard int channel
  49. - Function with no params and no returns
  50. - Function with param and no returns
  51. - Function with multiple params and multiple returns
  52. - Struct that is circular through self referencing
  53. - Structs that are circular through cross referencing
  54. - Structs that are indirectly circular
  55. - Type that panics in its Stringer interface
  56. - Type that has a custom Error interface
  57. - %x passthrough with uint
  58. - %#x passthrough with uint
  59. - %f passthrough with precision
  60. - %f passthrough with width and precision
  61. - %d passthrough with width
  62. - %q passthrough with string
  63. */
  64. package spew_test
  65. import (
  66. "bytes"
  67. "fmt"
  68. "github.com/davecgh/go-spew/spew"
  69. "testing"
  70. "unsafe"
  71. )
  72. // formatterTest is used to describe a test to be perfomed against NewFormatter.
  73. type formatterTest struct {
  74. format string
  75. in interface{}
  76. wants []string
  77. }
  78. // formatterTests houses all of the tests to be performed against NewFormatter.
  79. var formatterTests = make([]formatterTest, 0)
  80. // addFormatterTest is a helper method to append the passed input and desired
  81. // result to formatterTests.
  82. func addFormatterTest(format string, in interface{}, wants ...string) {
  83. test := formatterTest{format, in, wants}
  84. formatterTests = append(formatterTests, test)
  85. }
  86. func addIntFormatterTests() {
  87. // Max int8.
  88. v := int8(127)
  89. nv := (*int8)(nil)
  90. pv := &v
  91. vAddr := fmt.Sprintf("%p", pv)
  92. pvAddr := fmt.Sprintf("%p", &pv)
  93. vt := "int8"
  94. vs := "127"
  95. addFormatterTest("%v", v, vs)
  96. addFormatterTest("%v", pv, "<*>"+vs)
  97. addFormatterTest("%v", &pv, "<**>"+vs)
  98. addFormatterTest("%v", nv, "<nil>")
  99. addFormatterTest("%+v", v, vs)
  100. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  101. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  102. addFormatterTest("%+v", nv, "<nil>")
  103. addFormatterTest("%#v", v, "("+vt+")"+vs)
  104. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  105. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  106. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  107. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  108. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  109. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  110. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  111. // Max int16.
  112. v2 := int16(32767)
  113. nv2 := (*int16)(nil)
  114. pv2 := &v2
  115. v2Addr := fmt.Sprintf("%p", pv2)
  116. pv2Addr := fmt.Sprintf("%p", &pv2)
  117. v2t := "int16"
  118. v2s := "32767"
  119. addFormatterTest("%v", v2, v2s)
  120. addFormatterTest("%v", pv2, "<*>"+v2s)
  121. addFormatterTest("%v", &pv2, "<**>"+v2s)
  122. addFormatterTest("%v", nv2, "<nil>")
  123. addFormatterTest("%+v", v2, v2s)
  124. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s)
  125. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s)
  126. addFormatterTest("%+v", nv2, "<nil>")
  127. addFormatterTest("%#v", v2, "("+v2t+")"+v2s)
  128. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s)
  129. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s)
  130. addFormatterTest("%#v", nv2, "(*"+v2t+")"+"<nil>")
  131. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s)
  132. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s)
  133. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s)
  134. addFormatterTest("%#+v", nv2, "(*"+v2t+")"+"<nil>")
  135. // Max int32.
  136. v3 := int32(2147483647)
  137. nv3 := (*int32)(nil)
  138. pv3 := &v3
  139. v3Addr := fmt.Sprintf("%p", pv3)
  140. pv3Addr := fmt.Sprintf("%p", &pv3)
  141. v3t := "int32"
  142. v3s := "2147483647"
  143. addFormatterTest("%v", v3, v3s)
  144. addFormatterTest("%v", pv3, "<*>"+v3s)
  145. addFormatterTest("%v", &pv3, "<**>"+v3s)
  146. addFormatterTest("%v", nv3, "<nil>")
  147. addFormatterTest("%+v", v3, v3s)
  148. addFormatterTest("%+v", pv3, "<*>("+v3Addr+")"+v3s)
  149. addFormatterTest("%+v", &pv3, "<**>("+pv3Addr+"->"+v3Addr+")"+v3s)
  150. addFormatterTest("%+v", nv3, "<nil>")
  151. addFormatterTest("%#v", v3, "("+v3t+")"+v3s)
  152. addFormatterTest("%#v", pv3, "(*"+v3t+")"+v3s)
  153. addFormatterTest("%#v", &pv3, "(**"+v3t+")"+v3s)
  154. addFormatterTest("%#v", nv3, "(*"+v3t+")"+"<nil>")
  155. addFormatterTest("%#+v", v3, "("+v3t+")"+v3s)
  156. addFormatterTest("%#+v", pv3, "(*"+v3t+")("+v3Addr+")"+v3s)
  157. addFormatterTest("%#+v", &pv3, "(**"+v3t+")("+pv3Addr+"->"+v3Addr+")"+v3s)
  158. addFormatterTest("%#v", nv3, "(*"+v3t+")"+"<nil>")
  159. // Max int64.
  160. v4 := int64(9223372036854775807)
  161. nv4 := (*int64)(nil)
  162. pv4 := &v4
  163. v4Addr := fmt.Sprintf("%p", pv4)
  164. pv4Addr := fmt.Sprintf("%p", &pv4)
  165. v4t := "int64"
  166. v4s := "9223372036854775807"
  167. addFormatterTest("%v", v4, v4s)
  168. addFormatterTest("%v", pv4, "<*>"+v4s)
  169. addFormatterTest("%v", &pv4, "<**>"+v4s)
  170. addFormatterTest("%v", nv4, "<nil>")
  171. addFormatterTest("%+v", v4, v4s)
  172. addFormatterTest("%+v", pv4, "<*>("+v4Addr+")"+v4s)
  173. addFormatterTest("%+v", &pv4, "<**>("+pv4Addr+"->"+v4Addr+")"+v4s)
  174. addFormatterTest("%+v", nv4, "<nil>")
  175. addFormatterTest("%#v", v4, "("+v4t+")"+v4s)
  176. addFormatterTest("%#v", pv4, "(*"+v4t+")"+v4s)
  177. addFormatterTest("%#v", &pv4, "(**"+v4t+")"+v4s)
  178. addFormatterTest("%#v", nv4, "(*"+v4t+")"+"<nil>")
  179. addFormatterTest("%#+v", v4, "("+v4t+")"+v4s)
  180. addFormatterTest("%#+v", pv4, "(*"+v4t+")("+v4Addr+")"+v4s)
  181. addFormatterTest("%#+v", &pv4, "(**"+v4t+")("+pv4Addr+"->"+v4Addr+")"+v4s)
  182. addFormatterTest("%#+v", nv4, "(*"+v4t+")"+"<nil>")
  183. // Max int.
  184. v5 := int(2147483647)
  185. nv5 := (*int)(nil)
  186. pv5 := &v5
  187. v5Addr := fmt.Sprintf("%p", pv5)
  188. pv5Addr := fmt.Sprintf("%p", &pv5)
  189. v5t := "int"
  190. v5s := "2147483647"
  191. addFormatterTest("%v", v5, v5s)
  192. addFormatterTest("%v", pv5, "<*>"+v5s)
  193. addFormatterTest("%v", &pv5, "<**>"+v5s)
  194. addFormatterTest("%v", nv5, "<nil>")
  195. addFormatterTest("%+v", v5, v5s)
  196. addFormatterTest("%+v", pv5, "<*>("+v5Addr+")"+v5s)
  197. addFormatterTest("%+v", &pv5, "<**>("+pv5Addr+"->"+v5Addr+")"+v5s)
  198. addFormatterTest("%+v", nv5, "<nil>")
  199. addFormatterTest("%#v", v5, "("+v5t+")"+v5s)
  200. addFormatterTest("%#v", pv5, "(*"+v5t+")"+v5s)
  201. addFormatterTest("%#v", &pv5, "(**"+v5t+")"+v5s)
  202. addFormatterTest("%#v", nv5, "(*"+v5t+")"+"<nil>")
  203. addFormatterTest("%#+v", v5, "("+v5t+")"+v5s)
  204. addFormatterTest("%#+v", pv5, "(*"+v5t+")("+v5Addr+")"+v5s)
  205. addFormatterTest("%#+v", &pv5, "(**"+v5t+")("+pv5Addr+"->"+v5Addr+")"+v5s)
  206. addFormatterTest("%#+v", nv5, "(*"+v5t+")"+"<nil>")
  207. }
  208. func addUintFormatterTests() {
  209. // Max uint8.
  210. v := uint8(255)
  211. nv := (*uint8)(nil)
  212. pv := &v
  213. vAddr := fmt.Sprintf("%p", pv)
  214. pvAddr := fmt.Sprintf("%p", &pv)
  215. vt := "uint8"
  216. vs := "255"
  217. addFormatterTest("%v", v, vs)
  218. addFormatterTest("%v", pv, "<*>"+vs)
  219. addFormatterTest("%v", &pv, "<**>"+vs)
  220. addFormatterTest("%v", nv, "<nil>")
  221. addFormatterTest("%+v", v, vs)
  222. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  223. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  224. addFormatterTest("%+v", nv, "<nil>")
  225. addFormatterTest("%#v", v, "("+vt+")"+vs)
  226. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  227. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  228. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  229. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  230. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  231. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  232. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  233. // Max uint16.
  234. v2 := uint16(65535)
  235. nv2 := (*uint16)(nil)
  236. pv2 := &v2
  237. v2Addr := fmt.Sprintf("%p", pv2)
  238. pv2Addr := fmt.Sprintf("%p", &pv2)
  239. v2t := "uint16"
  240. v2s := "65535"
  241. addFormatterTest("%v", v2, v2s)
  242. addFormatterTest("%v", pv2, "<*>"+v2s)
  243. addFormatterTest("%v", &pv2, "<**>"+v2s)
  244. addFormatterTest("%v", nv2, "<nil>")
  245. addFormatterTest("%+v", v2, v2s)
  246. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s)
  247. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s)
  248. addFormatterTest("%+v", nv2, "<nil>")
  249. addFormatterTest("%#v", v2, "("+v2t+")"+v2s)
  250. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s)
  251. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s)
  252. addFormatterTest("%#v", nv2, "(*"+v2t+")"+"<nil>")
  253. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s)
  254. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s)
  255. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s)
  256. addFormatterTest("%#+v", nv2, "(*"+v2t+")"+"<nil>")
  257. // Max uint32.
  258. v3 := uint32(4294967295)
  259. nv3 := (*uint32)(nil)
  260. pv3 := &v3
  261. v3Addr := fmt.Sprintf("%p", pv3)
  262. pv3Addr := fmt.Sprintf("%p", &pv3)
  263. v3t := "uint32"
  264. v3s := "4294967295"
  265. addFormatterTest("%v", v3, v3s)
  266. addFormatterTest("%v", pv3, "<*>"+v3s)
  267. addFormatterTest("%v", &pv3, "<**>"+v3s)
  268. addFormatterTest("%v", nv3, "<nil>")
  269. addFormatterTest("%+v", v3, v3s)
  270. addFormatterTest("%+v", pv3, "<*>("+v3Addr+")"+v3s)
  271. addFormatterTest("%+v", &pv3, "<**>("+pv3Addr+"->"+v3Addr+")"+v3s)
  272. addFormatterTest("%+v", nv3, "<nil>")
  273. addFormatterTest("%#v", v3, "("+v3t+")"+v3s)
  274. addFormatterTest("%#v", pv3, "(*"+v3t+")"+v3s)
  275. addFormatterTest("%#v", &pv3, "(**"+v3t+")"+v3s)
  276. addFormatterTest("%#v", nv3, "(*"+v3t+")"+"<nil>")
  277. addFormatterTest("%#+v", v3, "("+v3t+")"+v3s)
  278. addFormatterTest("%#+v", pv3, "(*"+v3t+")("+v3Addr+")"+v3s)
  279. addFormatterTest("%#+v", &pv3, "(**"+v3t+")("+pv3Addr+"->"+v3Addr+")"+v3s)
  280. addFormatterTest("%#v", nv3, "(*"+v3t+")"+"<nil>")
  281. // Max uint64.
  282. v4 := uint64(18446744073709551615)
  283. nv4 := (*uint64)(nil)
  284. pv4 := &v4
  285. v4Addr := fmt.Sprintf("%p", pv4)
  286. pv4Addr := fmt.Sprintf("%p", &pv4)
  287. v4t := "uint64"
  288. v4s := "18446744073709551615"
  289. addFormatterTest("%v", v4, v4s)
  290. addFormatterTest("%v", pv4, "<*>"+v4s)
  291. addFormatterTest("%v", &pv4, "<**>"+v4s)
  292. addFormatterTest("%v", nv4, "<nil>")
  293. addFormatterTest("%+v", v4, v4s)
  294. addFormatterTest("%+v", pv4, "<*>("+v4Addr+")"+v4s)
  295. addFormatterTest("%+v", &pv4, "<**>("+pv4Addr+"->"+v4Addr+")"+v4s)
  296. addFormatterTest("%+v", nv4, "<nil>")
  297. addFormatterTest("%#v", v4, "("+v4t+")"+v4s)
  298. addFormatterTest("%#v", pv4, "(*"+v4t+")"+v4s)
  299. addFormatterTest("%#v", &pv4, "(**"+v4t+")"+v4s)
  300. addFormatterTest("%#v", nv4, "(*"+v4t+")"+"<nil>")
  301. addFormatterTest("%#+v", v4, "("+v4t+")"+v4s)
  302. addFormatterTest("%#+v", pv4, "(*"+v4t+")("+v4Addr+")"+v4s)
  303. addFormatterTest("%#+v", &pv4, "(**"+v4t+")("+pv4Addr+"->"+v4Addr+")"+v4s)
  304. addFormatterTest("%#+v", nv4, "(*"+v4t+")"+"<nil>")
  305. // Max uint.
  306. v5 := uint(4294967295)
  307. nv5 := (*uint)(nil)
  308. pv5 := &v5
  309. v5Addr := fmt.Sprintf("%p", pv5)
  310. pv5Addr := fmt.Sprintf("%p", &pv5)
  311. v5t := "uint"
  312. v5s := "4294967295"
  313. addFormatterTest("%v", v5, v5s)
  314. addFormatterTest("%v", pv5, "<*>"+v5s)
  315. addFormatterTest("%v", &pv5, "<**>"+v5s)
  316. addFormatterTest("%v", nv5, "<nil>")
  317. addFormatterTest("%+v", v5, v5s)
  318. addFormatterTest("%+v", pv5, "<*>("+v5Addr+")"+v5s)
  319. addFormatterTest("%+v", &pv5, "<**>("+pv5Addr+"->"+v5Addr+")"+v5s)
  320. addFormatterTest("%+v", nv5, "<nil>")
  321. addFormatterTest("%#v", v5, "("+v5t+")"+v5s)
  322. addFormatterTest("%#v", pv5, "(*"+v5t+")"+v5s)
  323. addFormatterTest("%#v", &pv5, "(**"+v5t+")"+v5s)
  324. addFormatterTest("%#v", nv5, "(*"+v5t+")"+"<nil>")
  325. addFormatterTest("%#+v", v5, "("+v5t+")"+v5s)
  326. addFormatterTest("%#+v", pv5, "(*"+v5t+")("+v5Addr+")"+v5s)
  327. addFormatterTest("%#+v", &pv5, "(**"+v5t+")("+pv5Addr+"->"+v5Addr+")"+v5s)
  328. addFormatterTest("%#v", nv5, "(*"+v5t+")"+"<nil>")
  329. }
  330. func addBoolFormatterTests() {
  331. // Boolean true.
  332. v := bool(true)
  333. nv := (*bool)(nil)
  334. pv := &v
  335. vAddr := fmt.Sprintf("%p", pv)
  336. pvAddr := fmt.Sprintf("%p", &pv)
  337. vt := "bool"
  338. vs := "true"
  339. addFormatterTest("%v", v, vs)
  340. addFormatterTest("%v", pv, "<*>"+vs)
  341. addFormatterTest("%v", &pv, "<**>"+vs)
  342. addFormatterTest("%v", nv, "<nil>")
  343. addFormatterTest("%+v", v, vs)
  344. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  345. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  346. addFormatterTest("%+v", nv, "<nil>")
  347. addFormatterTest("%#v", v, "("+vt+")"+vs)
  348. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  349. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  350. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  351. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  352. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  353. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  354. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  355. // Boolean false.
  356. v2 := bool(false)
  357. pv2 := &v2
  358. v2Addr := fmt.Sprintf("%p", pv2)
  359. pv2Addr := fmt.Sprintf("%p", &pv2)
  360. v2t := "bool"
  361. v2s := "false"
  362. addFormatterTest("%v", v2, v2s)
  363. addFormatterTest("%v", pv2, "<*>"+v2s)
  364. addFormatterTest("%v", &pv2, "<**>"+v2s)
  365. addFormatterTest("%+v", v2, v2s)
  366. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s)
  367. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s)
  368. addFormatterTest("%#v", v2, "("+v2t+")"+v2s)
  369. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s)
  370. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s)
  371. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s)
  372. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s)
  373. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s)
  374. }
  375. func addFloatFormatterTests() {
  376. // Standard float32.
  377. v := float32(3.1415)
  378. nv := (*float32)(nil)
  379. pv := &v
  380. vAddr := fmt.Sprintf("%p", pv)
  381. pvAddr := fmt.Sprintf("%p", &pv)
  382. vt := "float32"
  383. vs := "3.1415"
  384. addFormatterTest("%v", v, vs)
  385. addFormatterTest("%v", pv, "<*>"+vs)
  386. addFormatterTest("%v", &pv, "<**>"+vs)
  387. addFormatterTest("%v", nv, "<nil>")
  388. addFormatterTest("%+v", v, vs)
  389. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  390. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  391. addFormatterTest("%+v", nv, "<nil>")
  392. addFormatterTest("%#v", v, "("+vt+")"+vs)
  393. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  394. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  395. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  396. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  397. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  398. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  399. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  400. // Standard float64.
  401. v2 := float64(3.1415926)
  402. nv2 := (*float64)(nil)
  403. pv2 := &v2
  404. v2Addr := fmt.Sprintf("%p", pv2)
  405. pv2Addr := fmt.Sprintf("%p", &pv2)
  406. v2t := "float64"
  407. v2s := "3.1415926"
  408. addFormatterTest("%v", v2, v2s)
  409. addFormatterTest("%v", pv2, "<*>"+v2s)
  410. addFormatterTest("%v", &pv2, "<**>"+v2s)
  411. addFormatterTest("%+v", nv2, "<nil>")
  412. addFormatterTest("%+v", v2, v2s)
  413. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s)
  414. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s)
  415. addFormatterTest("%+v", nv2, "<nil>")
  416. addFormatterTest("%#v", v2, "("+v2t+")"+v2s)
  417. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s)
  418. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s)
  419. addFormatterTest("%#v", nv2, "(*"+v2t+")"+"<nil>")
  420. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s)
  421. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s)
  422. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s)
  423. addFormatterTest("%#+v", nv2, "(*"+v2t+")"+"<nil>")
  424. }
  425. func addComplexFormatterTests() {
  426. // Standard complex64.
  427. v := complex(float32(6), -2)
  428. nv := (*complex64)(nil)
  429. pv := &v
  430. vAddr := fmt.Sprintf("%p", pv)
  431. pvAddr := fmt.Sprintf("%p", &pv)
  432. vt := "complex64"
  433. vs := "(6-2i)"
  434. addFormatterTest("%v", v, vs)
  435. addFormatterTest("%v", pv, "<*>"+vs)
  436. addFormatterTest("%v", &pv, "<**>"+vs)
  437. addFormatterTest("%+v", nv, "<nil>")
  438. addFormatterTest("%+v", v, vs)
  439. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  440. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  441. addFormatterTest("%+v", nv, "<nil>")
  442. addFormatterTest("%#v", v, "("+vt+")"+vs)
  443. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  444. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  445. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  446. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  447. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  448. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  449. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  450. // Standard complex128.
  451. v2 := complex(float64(-6), 2)
  452. nv2 := (*complex128)(nil)
  453. pv2 := &v2
  454. v2Addr := fmt.Sprintf("%p", pv2)
  455. pv2Addr := fmt.Sprintf("%p", &pv2)
  456. v2t := "complex128"
  457. v2s := "(-6+2i)"
  458. addFormatterTest("%v", v2, v2s)
  459. addFormatterTest("%v", pv2, "<*>"+v2s)
  460. addFormatterTest("%v", &pv2, "<**>"+v2s)
  461. addFormatterTest("%+v", nv2, "<nil>")
  462. addFormatterTest("%+v", v2, v2s)
  463. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s)
  464. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s)
  465. addFormatterTest("%+v", nv2, "<nil>")
  466. addFormatterTest("%#v", v2, "("+v2t+")"+v2s)
  467. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s)
  468. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s)
  469. addFormatterTest("%#v", nv2, "(*"+v2t+")"+"<nil>")
  470. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s)
  471. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s)
  472. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s)
  473. addFormatterTest("%#+v", nv2, "(*"+v2t+")"+"<nil>")
  474. }
  475. func addArrayFormatterTests() {
  476. // Array containing standard ints.
  477. v := [3]int{1, 2, 3}
  478. nv := (*[3]int)(nil)
  479. pv := &v
  480. vAddr := fmt.Sprintf("%p", pv)
  481. pvAddr := fmt.Sprintf("%p", &pv)
  482. vt := "[3]int"
  483. vs := "[1 2 3]"
  484. addFormatterTest("%v", v, vs)
  485. addFormatterTest("%v", pv, "<*>"+vs)
  486. addFormatterTest("%v", &pv, "<**>"+vs)
  487. addFormatterTest("%+v", nv, "<nil>")
  488. addFormatterTest("%+v", v, vs)
  489. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  490. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  491. addFormatterTest("%+v", nv, "<nil>")
  492. addFormatterTest("%#v", v, "("+vt+")"+vs)
  493. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  494. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  495. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  496. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  497. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  498. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  499. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  500. // Array containing type with custom formatter on pointer receiver only.
  501. v2 := [3]pstringer{"1", "2", "3"}
  502. nv2 := (*[3]pstringer)(nil)
  503. pv2 := &v2
  504. v2Addr := fmt.Sprintf("%p", pv2)
  505. pv2Addr := fmt.Sprintf("%p", &pv2)
  506. v2t := "[3]spew_test.pstringer"
  507. v2s := "[stringer 1 stringer 2 stringer 3]"
  508. addFormatterTest("%v", v2, v2s)
  509. addFormatterTest("%v", pv2, "<*>"+v2s)
  510. addFormatterTest("%v", &pv2, "<**>"+v2s)
  511. addFormatterTest("%+v", nv2, "<nil>")
  512. addFormatterTest("%+v", v2, v2s)
  513. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s)
  514. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s)
  515. addFormatterTest("%+v", nv2, "<nil>")
  516. addFormatterTest("%#v", v2, "("+v2t+")"+v2s)
  517. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s)
  518. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s)
  519. addFormatterTest("%#v", nv2, "(*"+v2t+")"+"<nil>")
  520. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s)
  521. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s)
  522. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s)
  523. addFormatterTest("%#+v", nv2, "(*"+v2t+")"+"<nil>")
  524. // Array containing interfaces.
  525. v3 := [3]interface{}{"one", int(2), uint(3)}
  526. nv3 := (*[3]interface{})(nil)
  527. pv3 := &v3
  528. v3Addr := fmt.Sprintf("%p", pv3)
  529. pv3Addr := fmt.Sprintf("%p", &pv3)
  530. v3t := "[3]interface {}"
  531. v3t2 := "string"
  532. v3t3 := "int"
  533. v3t4 := "uint"
  534. v3s := "[one 2 3]"
  535. v3s2 := "[(" + v3t2 + ")one (" + v3t3 + ")2 (" + v3t4 + ")3]"
  536. addFormatterTest("%v", v3, v3s)
  537. addFormatterTest("%v", pv3, "<*>"+v3s)
  538. addFormatterTest("%v", &pv3, "<**>"+v3s)
  539. addFormatterTest("%+v", nv3, "<nil>")
  540. addFormatterTest("%+v", v3, v3s)
  541. addFormatterTest("%+v", pv3, "<*>("+v3Addr+")"+v3s)
  542. addFormatterTest("%+v", &pv3, "<**>("+pv3Addr+"->"+v3Addr+")"+v3s)
  543. addFormatterTest("%+v", nv3, "<nil>")
  544. addFormatterTest("%#v", v3, "("+v3t+")"+v3s2)
  545. addFormatterTest("%#v", pv3, "(*"+v3t+")"+v3s2)
  546. addFormatterTest("%#v", &pv3, "(**"+v3t+")"+v3s2)
  547. addFormatterTest("%#v", nv3, "(*"+v3t+")"+"<nil>")
  548. addFormatterTest("%#+v", v3, "("+v3t+")"+v3s2)
  549. addFormatterTest("%#+v", pv3, "(*"+v3t+")("+v3Addr+")"+v3s2)
  550. addFormatterTest("%#+v", &pv3, "(**"+v3t+")("+pv3Addr+"->"+v3Addr+")"+v3s2)
  551. addFormatterTest("%#+v", nv3, "(*"+v3t+")"+"<nil>")
  552. }
  553. func addSliceFormatterTests() {
  554. // Slice containing standard float32 values.
  555. v := []float32{3.14, 6.28, 12.56}
  556. nv := (*[]float32)(nil)
  557. pv := &v
  558. vAddr := fmt.Sprintf("%p", pv)
  559. pvAddr := fmt.Sprintf("%p", &pv)
  560. vt := "[]float32"
  561. vs := "[3.14 6.28 12.56]"
  562. addFormatterTest("%v", v, vs)
  563. addFormatterTest("%v", pv, "<*>"+vs)
  564. addFormatterTest("%v", &pv, "<**>"+vs)
  565. addFormatterTest("%+v", nv, "<nil>")
  566. addFormatterTest("%+v", v, vs)
  567. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  568. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  569. addFormatterTest("%+v", nv, "<nil>")
  570. addFormatterTest("%#v", v, "("+vt+")"+vs)
  571. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  572. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  573. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  574. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  575. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  576. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  577. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  578. // Slice containing type with custom formatter on pointer receiver only.
  579. v2 := []pstringer{"1", "2", "3"}
  580. nv2 := (*[]pstringer)(nil)
  581. pv2 := &v2
  582. v2Addr := fmt.Sprintf("%p", pv2)
  583. pv2Addr := fmt.Sprintf("%p", &pv2)
  584. v2t := "[]spew_test.pstringer"
  585. v2s := "[stringer 1 stringer 2 stringer 3]"
  586. addFormatterTest("%v", v2, v2s)
  587. addFormatterTest("%v", pv2, "<*>"+v2s)
  588. addFormatterTest("%v", &pv2, "<**>"+v2s)
  589. addFormatterTest("%+v", nv2, "<nil>")
  590. addFormatterTest("%+v", v2, v2s)
  591. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s)
  592. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s)
  593. addFormatterTest("%+v", nv2, "<nil>")
  594. addFormatterTest("%#v", v2, "("+v2t+")"+v2s)
  595. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s)
  596. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s)
  597. addFormatterTest("%#v", nv2, "(*"+v2t+")"+"<nil>")
  598. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s)
  599. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s)
  600. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s)
  601. addFormatterTest("%#+v", nv2, "(*"+v2t+")"+"<nil>")
  602. // Slice containing interfaces.
  603. v3 := []interface{}{"one", int(2), uint(3), nil}
  604. nv3 := (*[]interface{})(nil)
  605. pv3 := &v3
  606. v3Addr := fmt.Sprintf("%p", pv3)
  607. pv3Addr := fmt.Sprintf("%p", &pv3)
  608. v3t := "[]interface {}"
  609. v3t2 := "string"
  610. v3t3 := "int"
  611. v3t4 := "uint"
  612. v3t5 := "interface {}"
  613. v3s := "[one 2 3 <nil>]"
  614. v3s2 := "[(" + v3t2 + ")one (" + v3t3 + ")2 (" + v3t4 + ")3 (" + v3t5 +
  615. ")<nil>]"
  616. addFormatterTest("%v", v3, v3s)
  617. addFormatterTest("%v", pv3, "<*>"+v3s)
  618. addFormatterTest("%v", &pv3, "<**>"+v3s)
  619. addFormatterTest("%+v", nv3, "<nil>")
  620. addFormatterTest("%+v", v3, v3s)
  621. addFormatterTest("%+v", pv3, "<*>("+v3Addr+")"+v3s)
  622. addFormatterTest("%+v", &pv3, "<**>("+pv3Addr+"->"+v3Addr+")"+v3s)
  623. addFormatterTest("%+v", nv3, "<nil>")
  624. addFormatterTest("%#v", v3, "("+v3t+")"+v3s2)
  625. addFormatterTest("%#v", pv3, "(*"+v3t+")"+v3s2)
  626. addFormatterTest("%#v", &pv3, "(**"+v3t+")"+v3s2)
  627. addFormatterTest("%#v", nv3, "(*"+v3t+")"+"<nil>")
  628. addFormatterTest("%#+v", v3, "("+v3t+")"+v3s2)
  629. addFormatterTest("%#+v", pv3, "(*"+v3t+")("+v3Addr+")"+v3s2)
  630. addFormatterTest("%#+v", &pv3, "(**"+v3t+")("+pv3Addr+"->"+v3Addr+")"+v3s2)
  631. addFormatterTest("%#+v", nv3, "(*"+v3t+")"+"<nil>")
  632. // Nil slice.
  633. var v4 []int
  634. nv4 := (*[]int)(nil)
  635. pv4 := &v4
  636. v4Addr := fmt.Sprintf("%p", pv4)
  637. pv4Addr := fmt.Sprintf("%p", &pv4)
  638. v4t := "[]int"
  639. v4s := "<nil>"
  640. addFormatterTest("%v", v4, v4s)
  641. addFormatterTest("%v", pv4, "<*>"+v4s)
  642. addFormatterTest("%v", &pv4, "<**>"+v4s)
  643. addFormatterTest("%+v", nv4, "<nil>")
  644. addFormatterTest("%+v", v4, v4s)
  645. addFormatterTest("%+v", pv4, "<*>("+v4Addr+")"+v4s)
  646. addFormatterTest("%+v", &pv4, "<**>("+pv4Addr+"->"+v4Addr+")"+v4s)
  647. addFormatterTest("%+v", nv4, "<nil>")
  648. addFormatterTest("%#v", v4, "("+v4t+")"+v4s)
  649. addFormatterTest("%#v", pv4, "(*"+v4t+")"+v4s)
  650. addFormatterTest("%#v", &pv4, "(**"+v4t+")"+v4s)
  651. addFormatterTest("%#v", nv4, "(*"+v4t+")"+"<nil>")
  652. addFormatterTest("%#+v", v4, "("+v4t+")"+v4s)
  653. addFormatterTest("%#+v", pv4, "(*"+v4t+")("+v4Addr+")"+v4s)
  654. addFormatterTest("%#+v", &pv4, "(**"+v4t+")("+pv4Addr+"->"+v4Addr+")"+v4s)
  655. addFormatterTest("%#+v", nv4, "(*"+v4t+")"+"<nil>")
  656. }
  657. func addStringFormatterTests() {
  658. // Standard string.
  659. v := "test"
  660. nv := (*string)(nil)
  661. pv := &v
  662. vAddr := fmt.Sprintf("%p", pv)
  663. pvAddr := fmt.Sprintf("%p", &pv)
  664. vt := "string"
  665. vs := "test"
  666. addFormatterTest("%v", v, vs)
  667. addFormatterTest("%v", pv, "<*>"+vs)
  668. addFormatterTest("%v", &pv, "<**>"+vs)
  669. addFormatterTest("%+v", nv, "<nil>")
  670. addFormatterTest("%+v", v, vs)
  671. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  672. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  673. addFormatterTest("%+v", nv, "<nil>")
  674. addFormatterTest("%#v", v, "("+vt+")"+vs)
  675. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  676. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  677. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  678. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  679. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  680. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  681. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  682. }
  683. func addInterfaceFormatterTests() {
  684. // Nil interface.
  685. var v interface{}
  686. nv := (*interface{})(nil)
  687. pv := &v
  688. vAddr := fmt.Sprintf("%p", pv)
  689. pvAddr := fmt.Sprintf("%p", &pv)
  690. vt := "interface {}"
  691. vs := "<nil>"
  692. addFormatterTest("%v", v, vs)
  693. addFormatterTest("%v", pv, "<*>"+vs)
  694. addFormatterTest("%v", &pv, "<**>"+vs)
  695. addFormatterTest("%+v", nv, "<nil>")
  696. addFormatterTest("%+v", v, vs)
  697. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  698. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  699. addFormatterTest("%+v", nv, "<nil>")
  700. addFormatterTest("%#v", v, "("+vt+")"+vs)
  701. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  702. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  703. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  704. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  705. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  706. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  707. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  708. // Sub-interface.
  709. v2 := interface{}(uint16(65535))
  710. pv2 := &v2
  711. v2Addr := fmt.Sprintf("%p", pv2)
  712. pv2Addr := fmt.Sprintf("%p", &pv2)
  713. v2t := "uint16"
  714. v2s := "65535"
  715. addFormatterTest("%v", v2, v2s)
  716. addFormatterTest("%v", pv2, "<*>"+v2s)
  717. addFormatterTest("%v", &pv2, "<**>"+v2s)
  718. addFormatterTest("%+v", v2, v2s)
  719. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s)
  720. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s)
  721. addFormatterTest("%#v", v2, "("+v2t+")"+v2s)
  722. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s)
  723. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s)
  724. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s)
  725. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s)
  726. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s)
  727. }
  728. func addMapFormatterTests() {
  729. // Map with string keys and int vals.
  730. v := map[string]int{"one": 1, "two": 2}
  731. nv := (*map[string]int)(nil)
  732. pv := &v
  733. vAddr := fmt.Sprintf("%p", pv)
  734. pvAddr := fmt.Sprintf("%p", &pv)
  735. vt := "map[string]int"
  736. vs := "map[one:1 two:2]"
  737. vs2 := "map[two:2 one:1]"
  738. addFormatterTest("%v", v, vs, vs2)
  739. addFormatterTest("%v", pv, "<*>"+vs, "<*>"+vs2)
  740. addFormatterTest("%v", &pv, "<**>"+vs, "<**>"+vs2)
  741. addFormatterTest("%+v", nv, "<nil>")
  742. addFormatterTest("%+v", v, vs, vs2)
  743. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs, "<*>("+vAddr+")"+vs2)
  744. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs,
  745. "<**>("+pvAddr+"->"+vAddr+")"+vs2)
  746. addFormatterTest("%+v", nv, "<nil>")
  747. addFormatterTest("%#v", v, "("+vt+")"+vs, "("+vt+")"+vs2)
  748. addFormatterTest("%#v", pv, "(*"+vt+")"+vs, "(*"+vt+")"+vs2)
  749. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs, "(**"+vt+")"+vs2)
  750. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  751. addFormatterTest("%#+v", v, "("+vt+")"+vs, "("+vt+")"+vs2)
  752. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs,
  753. "(*"+vt+")("+vAddr+")"+vs2)
  754. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs,
  755. "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs2)
  756. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  757. // Map with custom formatter type on pointer receiver only keys and vals.
  758. v2 := map[pstringer]pstringer{"one": "1"}
  759. nv2 := (*map[pstringer]pstringer)(nil)
  760. pv2 := &v2
  761. v2Addr := fmt.Sprintf("%p", pv2)
  762. pv2Addr := fmt.Sprintf("%p", &pv2)
  763. v2t := "map[spew_test.pstringer]spew_test.pstringer"
  764. v2s := "map[stringer one:stringer 1]"
  765. addFormatterTest("%v", v2, v2s)
  766. addFormatterTest("%v", pv2, "<*>"+v2s)
  767. addFormatterTest("%v", &pv2, "<**>"+v2s)
  768. addFormatterTest("%+v", nv2, "<nil>")
  769. addFormatterTest("%+v", v2, v2s)
  770. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s)
  771. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s)
  772. addFormatterTest("%+v", nv2, "<nil>")
  773. addFormatterTest("%#v", v2, "("+v2t+")"+v2s)
  774. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s)
  775. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s)
  776. addFormatterTest("%#v", nv2, "(*"+v2t+")"+"<nil>")
  777. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s)
  778. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s)
  779. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s)
  780. addFormatterTest("%#+v", nv2, "(*"+v2t+")"+"<nil>")
  781. // Map with interface keys and values.
  782. v3 := map[interface{}]interface{}{"one": 1}
  783. nv3 := (*map[interface{}]interface{})(nil)
  784. pv3 := &v3
  785. v3Addr := fmt.Sprintf("%p", pv3)
  786. pv3Addr := fmt.Sprintf("%p", &pv3)
  787. v3t := "map[interface {}]interface {}"
  788. v3t1 := "string"
  789. v3t2 := "int"
  790. v3s := "map[one:1]"
  791. v3s2 := "map[(" + v3t1 + ")one:(" + v3t2 + ")1]"
  792. addFormatterTest("%v", v3, v3s)
  793. addFormatterTest("%v", pv3, "<*>"+v3s)
  794. addFormatterTest("%v", &pv3, "<**>"+v3s)
  795. addFormatterTest("%+v", nv3, "<nil>")
  796. addFormatterTest("%+v", v3, v3s)
  797. addFormatterTest("%+v", pv3, "<*>("+v3Addr+")"+v3s)
  798. addFormatterTest("%+v", &pv3, "<**>("+pv3Addr+"->"+v3Addr+")"+v3s)
  799. addFormatterTest("%+v", nv3, "<nil>")
  800. addFormatterTest("%#v", v3, "("+v3t+")"+v3s2)
  801. addFormatterTest("%#v", pv3, "(*"+v3t+")"+v3s2)
  802. addFormatterTest("%#v", &pv3, "(**"+v3t+")"+v3s2)
  803. addFormatterTest("%#v", nv3, "(*"+v3t+")"+"<nil>")
  804. addFormatterTest("%#+v", v3, "("+v3t+")"+v3s2)
  805. addFormatterTest("%#+v", pv3, "(*"+v3t+")("+v3Addr+")"+v3s2)
  806. addFormatterTest("%#+v", &pv3, "(**"+v3t+")("+pv3Addr+"->"+v3Addr+")"+v3s2)
  807. addFormatterTest("%#+v", nv3, "(*"+v3t+")"+"<nil>")
  808. // Map with nil interface value
  809. v4 := map[string]interface{}{"nil": nil}
  810. nv4 := (*map[string]interface{})(nil)
  811. pv4 := &v4
  812. v4Addr := fmt.Sprintf("%p", pv4)
  813. pv4Addr := fmt.Sprintf("%p", &pv4)
  814. v4t := "map[string]interface {}"
  815. v4t1 := "interface {}"
  816. v4s := "map[nil:<nil>]"
  817. v4s2 := "map[nil:(" + v4t1 + ")<nil>]"
  818. addFormatterTest("%v", v4, v4s)
  819. addFormatterTest("%v", pv4, "<*>"+v4s)
  820. addFormatterTest("%v", &pv4, "<**>"+v4s)
  821. addFormatterTest("%+v", nv4, "<nil>")
  822. addFormatterTest("%+v", v4, v4s)
  823. addFormatterTest("%+v", pv4, "<*>("+v4Addr+")"+v4s)
  824. addFormatterTest("%+v", &pv4, "<**>("+pv4Addr+"->"+v4Addr+")"+v4s)
  825. addFormatterTest("%+v", nv4, "<nil>")
  826. addFormatterTest("%#v", v4, "("+v4t+")"+v4s2)
  827. addFormatterTest("%#v", pv4, "(*"+v4t+")"+v4s2)
  828. addFormatterTest("%#v", &pv4, "(**"+v4t+")"+v4s2)
  829. addFormatterTest("%#v", nv4, "(*"+v4t+")"+"<nil>")
  830. addFormatterTest("%#+v", v4, "("+v4t+")"+v4s2)
  831. addFormatterTest("%#+v", pv4, "(*"+v4t+")("+v4Addr+")"+v4s2)
  832. addFormatterTest("%#+v", &pv4, "(**"+v4t+")("+pv4Addr+"->"+v4Addr+")"+v4s2)
  833. addFormatterTest("%#+v", nv4, "(*"+v4t+")"+"<nil>")
  834. }
  835. func addStructFormatterTests() {
  836. // Struct with primitives.
  837. type s1 struct {
  838. a int8
  839. b uint8
  840. }
  841. v := s1{127, 255}
  842. nv := (*s1)(nil)
  843. pv := &v
  844. vAddr := fmt.Sprintf("%p", pv)
  845. pvAddr := fmt.Sprintf("%p", &pv)
  846. vt := "spew_test.s1"
  847. vt2 := "int8"
  848. vt3 := "uint8"
  849. vs := "{127 255}"
  850. vs2 := "{a:127 b:255}"
  851. vs3 := "{a:(" + vt2 + ")127 b:(" + vt3 + ")255}"
  852. addFormatterTest("%v", v, vs)
  853. addFormatterTest("%v", pv, "<*>"+vs)
  854. addFormatterTest("%v", &pv, "<**>"+vs)
  855. addFormatterTest("%+v", nv, "<nil>")
  856. addFormatterTest("%+v", v, vs2)
  857. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs2)
  858. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs2)
  859. addFormatterTest("%+v", nv, "<nil>")
  860. addFormatterTest("%#v", v, "("+vt+")"+vs3)
  861. addFormatterTest("%#v", pv, "(*"+vt+")"+vs3)
  862. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs3)
  863. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  864. addFormatterTest("%#+v", v, "("+vt+")"+vs3)
  865. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs3)
  866. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs3)
  867. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  868. // Struct that contains another struct.
  869. type s2 struct {
  870. s1 s1
  871. b bool
  872. }
  873. v2 := s2{s1{127, 255}, true}
  874. nv2 := (*s2)(nil)
  875. pv2 := &v2
  876. v2Addr := fmt.Sprintf("%p", pv2)
  877. pv2Addr := fmt.Sprintf("%p", &pv2)
  878. v2t := "spew_test.s2"
  879. v2t2 := "spew_test.s1"
  880. v2t3 := "int8"
  881. v2t4 := "uint8"
  882. v2t5 := "bool"
  883. v2s := "{{127 255} true}"
  884. v2s2 := "{s1:{a:127 b:255} b:true}"
  885. v2s3 := "{s1:(" + v2t2 + "){a:(" + v2t3 + ")127 b:(" + v2t4 + ")255} b:(" +
  886. v2t5 + ")true}"
  887. addFormatterTest("%v", v2, v2s)
  888. addFormatterTest("%v", pv2, "<*>"+v2s)
  889. addFormatterTest("%v", &pv2, "<**>"+v2s)
  890. addFormatterTest("%+v", nv2, "<nil>")
  891. addFormatterTest("%+v", v2, v2s2)
  892. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s2)
  893. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s2)
  894. addFormatterTest("%+v", nv2, "<nil>")
  895. addFormatterTest("%#v", v2, "("+v2t+")"+v2s3)
  896. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s3)
  897. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s3)
  898. addFormatterTest("%#v", nv2, "(*"+v2t+")"+"<nil>")
  899. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s3)
  900. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s3)
  901. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s3)
  902. addFormatterTest("%#+v", nv2, "(*"+v2t+")"+"<nil>")
  903. // Struct that contains custom type with Stringer pointer interface via both
  904. // exported and unexported fields.
  905. type s3 struct {
  906. s pstringer
  907. S pstringer
  908. }
  909. v3 := s3{"test", "test2"}
  910. nv3 := (*s3)(nil)
  911. pv3 := &v3
  912. v3Addr := fmt.Sprintf("%p", pv3)
  913. pv3Addr := fmt.Sprintf("%p", &pv3)
  914. v3t := "spew_test.s3"
  915. v3t2 := "spew_test.pstringer"
  916. v3s := "{stringer test stringer test2}"
  917. v3s2 := "{s:stringer test S:stringer test2}"
  918. v3s3 := "{s:(" + v3t2 + ")stringer test S:(" + v3t2 + ")stringer test2}"
  919. addFormatterTest("%v", v3, v3s)
  920. addFormatterTest("%v", pv3, "<*>"+v3s)
  921. addFormatterTest("%v", &pv3, "<**>"+v3s)
  922. addFormatterTest("%+v", nv3, "<nil>")
  923. addFormatterTest("%+v", v3, v3s2)
  924. addFormatterTest("%+v", pv3, "<*>("+v3Addr+")"+v3s2)
  925. addFormatterTest("%+v", &pv3, "<**>("+pv3Addr+"->"+v3Addr+")"+v3s2)
  926. addFormatterTest("%+v", nv3, "<nil>")
  927. addFormatterTest("%#v", v3, "("+v3t+")"+v3s3)
  928. addFormatterTest("%#v", pv3, "(*"+v3t+")"+v3s3)
  929. addFormatterTest("%#v", &pv3, "(**"+v3t+")"+v3s3)
  930. addFormatterTest("%#v", nv3, "(*"+v3t+")"+"<nil>")
  931. addFormatterTest("%#+v", v3, "("+v3t+")"+v3s3)
  932. addFormatterTest("%#+v", pv3, "(*"+v3t+")("+v3Addr+")"+v3s3)
  933. addFormatterTest("%#+v", &pv3, "(**"+v3t+")("+pv3Addr+"->"+v3Addr+")"+v3s3)
  934. addFormatterTest("%#+v", nv3, "(*"+v3t+")"+"<nil>")
  935. // Struct that contains embedded struct and field to same struct.
  936. e := embed{"embedstr"}
  937. v4 := embedwrap{embed: &e, e: &e}
  938. nv4 := (*embedwrap)(nil)
  939. pv4 := &v4
  940. eAddr := fmt.Sprintf("%p", &e)
  941. v4Addr := fmt.Sprintf("%p", pv4)
  942. pv4Addr := fmt.Sprintf("%p", &pv4)
  943. v4t := "spew_test.embedwrap"
  944. v4t2 := "spew_test.embed"
  945. v4t3 := "string"
  946. v4s := "{<*>{embedstr} <*>{embedstr}}"
  947. v4s2 := "{embed:<*>(" + eAddr + "){a:embedstr} e:<*>(" + eAddr +
  948. "){a:embedstr}}"
  949. v4s3 := "{embed:(*" + v4t2 + "){a:(" + v4t3 + ")embedstr} e:(*" + v4t2 +
  950. "){a:(" + v4t3 + ")embedstr}}"
  951. v4s4 := "{embed:(*" + v4t2 + ")(" + eAddr + "){a:(" + v4t3 +
  952. ")embedstr} e:(*" + v4t2 + ")(" + eAddr + "){a:(" + v4t3 + ")embedstr}}"
  953. addFormatterTest("%v", v4, v4s)
  954. addFormatterTest("%v", pv4, "<*>"+v4s)
  955. addFormatterTest("%v", &pv4, "<**>"+v4s)
  956. addFormatterTest("%+v", nv4, "<nil>")
  957. addFormatterTest("%+v", v4, v4s2)
  958. addFormatterTest("%+v", pv4, "<*>("+v4Addr+")"+v4s2)
  959. addFormatterTest("%+v", &pv4, "<**>("+pv4Addr+"->"+v4Addr+")"+v4s2)
  960. addFormatterTest("%+v", nv4, "<nil>")
  961. addFormatterTest("%#v", v4, "("+v4t+")"+v4s3)
  962. addFormatterTest("%#v", pv4, "(*"+v4t+")"+v4s3)
  963. addFormatterTest("%#v", &pv4, "(**"+v4t+")"+v4s3)
  964. addFormatterTest("%#v", nv4, "(*"+v4t+")"+"<nil>")
  965. addFormatterTest("%#+v", v4, "("+v4t+")"+v4s4)
  966. addFormatterTest("%#+v", pv4, "(*"+v4t+")("+v4Addr+")"+v4s4)
  967. addFormatterTest("%#+v", &pv4, "(**"+v4t+")("+pv4Addr+"->"+v4Addr+")"+v4s4)
  968. addFormatterTest("%#+v", nv4, "(*"+v4t+")"+"<nil>")
  969. }
  970. func addUintptrFormatterTests() {
  971. // Null pointer.
  972. v := uintptr(0)
  973. nv := (*uintptr)(nil)
  974. pv := &v
  975. vAddr := fmt.Sprintf("%p", pv)
  976. pvAddr := fmt.Sprintf("%p", &pv)
  977. vt := "uintptr"
  978. vs := "<nil>"
  979. addFormatterTest("%v", v, vs)
  980. addFormatterTest("%v", pv, "<*>"+vs)
  981. addFormatterTest("%v", &pv, "<**>"+vs)
  982. addFormatterTest("%+v", nv, "<nil>")
  983. addFormatterTest("%+v", v, vs)
  984. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  985. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  986. addFormatterTest("%+v", nv, "<nil>")
  987. addFormatterTest("%#v", v, "("+vt+")"+vs)
  988. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  989. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  990. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  991. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  992. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  993. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  994. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  995. // Address of real variable.
  996. i := 1
  997. v2 := uintptr(unsafe.Pointer(&i))
  998. pv2 := &v2
  999. v2Addr := fmt.Sprintf("%p", pv2)
  1000. pv2Addr := fmt.Sprintf("%p", &pv2)
  1001. v2t := "uintptr"
  1002. v2s := fmt.Sprintf("%p", &i)
  1003. addFormatterTest("%v", v2, v2s)
  1004. addFormatterTest("%v", pv2, "<*>"+v2s)
  1005. addFormatterTest("%v", &pv2, "<**>"+v2s)
  1006. addFormatterTest("%+v", v2, v2s)
  1007. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s)
  1008. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s)
  1009. addFormatterTest("%#v", v2, "("+v2t+")"+v2s)
  1010. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s)
  1011. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s)
  1012. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s)
  1013. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s)
  1014. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s)
  1015. }
  1016. func addUnsafePointerFormatterTests() {
  1017. // Null pointer.
  1018. v := unsafe.Pointer(uintptr(0))
  1019. nv := (*unsafe.Pointer)(nil)
  1020. pv := &v
  1021. vAddr := fmt.Sprintf("%p", pv)
  1022. pvAddr := fmt.Sprintf("%p", &pv)
  1023. vt := "unsafe.Pointer"
  1024. vs := "<nil>"
  1025. addFormatterTest("%v", v, vs)
  1026. addFormatterTest("%v", pv, "<*>"+vs)
  1027. addFormatterTest("%v", &pv, "<**>"+vs)
  1028. addFormatterTest("%+v", nv, "<nil>")
  1029. addFormatterTest("%+v", v, vs)
  1030. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  1031. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  1032. addFormatterTest("%+v", nv, "<nil>")
  1033. addFormatterTest("%#v", v, "("+vt+")"+vs)
  1034. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  1035. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  1036. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  1037. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  1038. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  1039. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  1040. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  1041. // Address of real variable.
  1042. i := 1
  1043. v2 := unsafe.Pointer(&i)
  1044. pv2 := &v2
  1045. v2Addr := fmt.Sprintf("%p", pv2)
  1046. pv2Addr := fmt.Sprintf("%p", &pv2)
  1047. v2t := "unsafe.Pointer"
  1048. v2s := fmt.Sprintf("%p", &i)
  1049. addFormatterTest("%v", v2, v2s)
  1050. addFormatterTest("%v", pv2, "<*>"+v2s)
  1051. addFormatterTest("%v", &pv2, "<**>"+v2s)
  1052. addFormatterTest("%+v", v2, v2s)
  1053. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s)
  1054. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s)
  1055. addFormatterTest("%#v", v2, "("+v2t+")"+v2s)
  1056. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s)
  1057. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s)
  1058. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s)
  1059. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s)
  1060. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s)
  1061. }
  1062. func addChanFormatterTests() {
  1063. // Nil channel.
  1064. var v chan int
  1065. pv := &v
  1066. nv := (*chan int)(nil)
  1067. vAddr := fmt.Sprintf("%p", pv)
  1068. pvAddr := fmt.Sprintf("%p", &pv)
  1069. vt := "chan int"
  1070. vs := "<nil>"
  1071. addFormatterTest("%v", v, vs)
  1072. addFormatterTest("%v", pv, "<*>"+vs)
  1073. addFormatterTest("%v", &pv, "<**>"+vs)
  1074. addFormatterTest("%+v", nv, "<nil>")
  1075. addFormatterTest("%+v", v, vs)
  1076. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  1077. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  1078. addFormatterTest("%+v", nv, "<nil>")
  1079. addFormatterTest("%#v", v, "("+vt+")"+vs)
  1080. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  1081. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  1082. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  1083. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  1084. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  1085. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  1086. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  1087. // Real channel.
  1088. v2 := make(chan int)
  1089. pv2 := &v2
  1090. v2Addr := fmt.Sprintf("%p", pv2)
  1091. pv2Addr := fmt.Sprintf("%p", &pv2)
  1092. v2t := "chan int"
  1093. v2s := fmt.Sprintf("%p", v2)
  1094. addFormatterTest("%v", v2, v2s)
  1095. addFormatterTest("%v", pv2, "<*>"+v2s)
  1096. addFormatterTest("%v", &pv2, "<**>"+v2s)
  1097. addFormatterTest("%+v", v2, v2s)
  1098. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s)
  1099. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s)
  1100. addFormatterTest("%#v", v2, "("+v2t+")"+v2s)
  1101. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s)
  1102. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s)
  1103. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s)
  1104. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s)
  1105. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s)
  1106. }
  1107. func addFuncFormatterTests() {
  1108. // Function with no params and no returns.
  1109. v := addIntFormatterTests
  1110. nv := (*func())(nil)
  1111. pv := &v
  1112. vAddr := fmt.Sprintf("%p", pv)
  1113. pvAddr := fmt.Sprintf("%p", &pv)
  1114. vt := "func()"
  1115. vs := fmt.Sprintf("%p", v)
  1116. addFormatterTest("%v", v, vs)
  1117. addFormatterTest("%v", pv, "<*>"+vs)
  1118. addFormatterTest("%v", &pv, "<**>"+vs)
  1119. addFormatterTest("%+v", nv, "<nil>")
  1120. addFormatterTest("%+v", v, vs)
  1121. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  1122. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  1123. addFormatterTest("%+v", nv, "<nil>")
  1124. addFormatterTest("%#v", v, "("+vt+")"+vs)
  1125. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  1126. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  1127. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  1128. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  1129. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  1130. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  1131. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  1132. // Function with param and no returns.
  1133. v2 := TestFormatter
  1134. nv2 := (*func(*testing.T))(nil)
  1135. pv2 := &v2
  1136. v2Addr := fmt.Sprintf("%p", pv2)
  1137. pv2Addr := fmt.Sprintf("%p", &pv2)
  1138. v2t := "func(*testing.T)"
  1139. v2s := fmt.Sprintf("%p", v2)
  1140. addFormatterTest("%v", v2, v2s)
  1141. addFormatterTest("%v", pv2, "<*>"+v2s)
  1142. addFormatterTest("%v", &pv2, "<**>"+v2s)
  1143. addFormatterTest("%+v", nv2, "<nil>")
  1144. addFormatterTest("%+v", v2, v2s)
  1145. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s)
  1146. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s)
  1147. addFormatterTest("%+v", nv2, "<nil>")
  1148. addFormatterTest("%#v", v2, "("+v2t+")"+v2s)
  1149. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s)
  1150. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s)
  1151. addFormatterTest("%#v", nv2, "(*"+v2t+")"+"<nil>")
  1152. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s)
  1153. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s)
  1154. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s)
  1155. addFormatterTest("%#+v", nv2, "(*"+v2t+")"+"<nil>")
  1156. // Function with multiple params and multiple returns.
  1157. var v3 = func(i int, s string) (b bool, err error) {
  1158. return true, nil
  1159. }
  1160. nv3 := (*func(int, string) (bool, error))(nil)
  1161. pv3 := &v3
  1162. v3Addr := fmt.Sprintf("%p", pv3)
  1163. pv3Addr := fmt.Sprintf("%p", &pv3)
  1164. v3t := "func(int, string) (bool, error)"
  1165. v3s := fmt.Sprintf("%p", v3)
  1166. addFormatterTest("%v", v3, v3s)
  1167. addFormatterTest("%v", pv3, "<*>"+v3s)
  1168. addFormatterTest("%v", &pv3, "<**>"+v3s)
  1169. addFormatterTest("%+v", nv3, "<nil>")
  1170. addFormatterTest("%+v", v3, v3s)
  1171. addFormatterTest("%+v", pv3, "<*>("+v3Addr+")"+v3s)
  1172. addFormatterTest("%+v", &pv3, "<**>("+pv3Addr+"->"+v3Addr+")"+v3s)
  1173. addFormatterTest("%+v", nv3, "<nil>")
  1174. addFormatterTest("%#v", v3, "("+v3t+")"+v3s)
  1175. addFormatterTest("%#v", pv3, "(*"+v3t+")"+v3s)
  1176. addFormatterTest("%#v", &pv3, "(**"+v3t+")"+v3s)
  1177. addFormatterTest("%#v", nv3, "(*"+v3t+")"+"<nil>")
  1178. addFormatterTest("%#+v", v3, "("+v3t+")"+v3s)
  1179. addFormatterTest("%#+v", pv3, "(*"+v3t+")("+v3Addr+")"+v3s)
  1180. addFormatterTest("%#+v", &pv3, "(**"+v3t+")("+pv3Addr+"->"+v3Addr+")"+v3s)
  1181. addFormatterTest("%#+v", nv3, "(*"+v3t+")"+"<nil>")
  1182. }
  1183. func addCircularFormatterTests() {
  1184. // Struct that is circular through self referencing.
  1185. type circular struct {
  1186. c *circular
  1187. }
  1188. v := circular{nil}
  1189. v.c = &v
  1190. pv := &v
  1191. vAddr := fmt.Sprintf("%p", pv)
  1192. pvAddr := fmt.Sprintf("%p", &pv)
  1193. vt := "spew_test.circular"
  1194. vs := "{<*>{<*><shown>}}"
  1195. vs2 := "{<*><shown>}"
  1196. vs3 := "{c:<*>(" + vAddr + "){c:<*>(" + vAddr + ")<shown>}}"
  1197. vs4 := "{c:<*>(" + vAddr + ")<shown>}"
  1198. vs5 := "{c:(*" + vt + "){c:(*" + vt + ")<shown>}}"
  1199. vs6 := "{c:(*" + vt + ")<shown>}"
  1200. vs7 := "{c:(*" + vt + ")(" + vAddr + "){c:(*" + vt + ")(" + vAddr +
  1201. ")<shown>}}"
  1202. vs8 := "{c:(*" + vt + ")(" + vAddr + ")<shown>}"
  1203. addFormatterTest("%v", v, vs)
  1204. addFormatterTest("%v", pv, "<*>"+vs2)
  1205. addFormatterTest("%v", &pv, "<**>"+vs2)
  1206. addFormatterTest("%+v", v, vs3)
  1207. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs4)
  1208. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs4)
  1209. addFormatterTest("%#v", v, "("+vt+")"+vs5)
  1210. addFormatterTest("%#v", pv, "(*"+vt+")"+vs6)
  1211. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs6)
  1212. addFormatterTest("%#+v", v, "("+vt+")"+vs7)
  1213. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs8)
  1214. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs8)
  1215. // Structs that are circular through cross referencing.
  1216. v2 := xref1{nil}
  1217. ts2 := xref2{&v2}
  1218. v2.ps2 = &ts2
  1219. pv2 := &v2
  1220. ts2Addr := fmt.Sprintf("%p", &ts2)
  1221. v2Addr := fmt.Sprintf("%p", pv2)
  1222. pv2Addr := fmt.Sprintf("%p", &pv2)
  1223. v2t := "spew_test.xref1"
  1224. v2t2 := "spew_test.xref2"
  1225. v2s := "{<*>{<*>{<*><shown>}}}"
  1226. v2s2 := "{<*>{<*><shown>}}"
  1227. v2s3 := "{ps2:<*>(" + ts2Addr + "){ps1:<*>(" + v2Addr + "){ps2:<*>(" +
  1228. ts2Addr + ")<shown>}}}"
  1229. v2s4 := "{ps2:<*>(" + ts2Addr + "){ps1:<*>(" + v2Addr + ")<shown>}}"
  1230. v2s5 := "{ps2:(*" + v2t2 + "){ps1:(*" + v2t + "){ps2:(*" + v2t2 +
  1231. ")<shown>}}}"
  1232. v2s6 := "{ps2:(*" + v2t2 + "){ps1:(*" + v2t + ")<shown>}}"
  1233. v2s7 := "{ps2:(*" + v2t2 + ")(" + ts2Addr + "){ps1:(*" + v2t +
  1234. ")(" + v2Addr + "){ps2:(*" + v2t2 + ")(" + ts2Addr +
  1235. ")<shown>}}}"
  1236. v2s8 := "{ps2:(*" + v2t2 + ")(" + ts2Addr + "){ps1:(*" + v2t +
  1237. ")(" + v2Addr + ")<shown>}}"
  1238. addFormatterTest("%v", v2, v2s)
  1239. addFormatterTest("%v", pv2, "<*>"+v2s2)
  1240. addFormatterTest("%v", &pv2, "<**>"+v2s2)
  1241. addFormatterTest("%+v", v2, v2s3)
  1242. addFormatterTest("%+v", pv2, "<*>("+v2Addr+")"+v2s4)
  1243. addFormatterTest("%+v", &pv2, "<**>("+pv2Addr+"->"+v2Addr+")"+v2s4)
  1244. addFormatterTest("%#v", v2, "("+v2t+")"+v2s5)
  1245. addFormatterTest("%#v", pv2, "(*"+v2t+")"+v2s6)
  1246. addFormatterTest("%#v", &pv2, "(**"+v2t+")"+v2s6)
  1247. addFormatterTest("%#+v", v2, "("+v2t+")"+v2s7)
  1248. addFormatterTest("%#+v", pv2, "(*"+v2t+")("+v2Addr+")"+v2s8)
  1249. addFormatterTest("%#+v", &pv2, "(**"+v2t+")("+pv2Addr+"->"+v2Addr+")"+v2s8)
  1250. // Structs that are indirectly circular.
  1251. v3 := indirCir1{nil}
  1252. tic2 := indirCir2{nil}
  1253. tic3 := indirCir3{&v3}
  1254. tic2.ps3 = &tic3
  1255. v3.ps2 = &tic2
  1256. pv3 := &v3
  1257. tic2Addr := fmt.Sprintf("%p", &tic2)
  1258. tic3Addr := fmt.Sprintf("%p", &tic3)
  1259. v3Addr := fmt.Sprintf("%p", pv3)
  1260. pv3Addr := fmt.Sprintf("%p", &pv3)
  1261. v3t := "spew_test.indirCir1"
  1262. v3t2 := "spew_test.indirCir2"
  1263. v3t3 := "spew_test.indirCir3"
  1264. v3s := "{<*>{<*>{<*>{<*><shown>}}}}"
  1265. v3s2 := "{<*>{<*>{<*><shown>}}}"
  1266. v3s3 := "{ps2:<*>(" + tic2Addr + "){ps3:<*>(" + tic3Addr + "){ps1:<*>(" +
  1267. v3Addr + "){ps2:<*>(" + tic2Addr + ")<shown>}}}}"
  1268. v3s4 := "{ps2:<*>(" + tic2Addr + "){ps3:<*>(" + tic3Addr + "){ps1:<*>(" +
  1269. v3Addr + ")<shown>}}}"
  1270. v3s5 := "{ps2:(*" + v3t2 + "){ps3:(*" + v3t3 + "){ps1:(*" + v3t +
  1271. "){ps2:(*" + v3t2 + ")<shown>}}}}"
  1272. v3s6 := "{ps2:(*" + v3t2 + "){ps3:(*" + v3t3 + "){ps1:(*" + v3t +
  1273. ")<shown>}}}"
  1274. v3s7 := "{ps2:(*" + v3t2 + ")(" + tic2Addr + "){ps3:(*" + v3t3 + ")(" +
  1275. tic3Addr + "){ps1:(*" + v3t + ")(" + v3Addr + "){ps2:(*" + v3t2 +
  1276. ")(" + tic2Addr + ")<shown>}}}}"
  1277. v3s8 := "{ps2:(*" + v3t2 + ")(" + tic2Addr + "){ps3:(*" + v3t3 + ")(" +
  1278. tic3Addr + "){ps1:(*" + v3t + ")(" + v3Addr + ")<shown>}}}"
  1279. addFormatterTest("%v", v3, v3s)
  1280. addFormatterTest("%v", pv3, "<*>"+v3s2)
  1281. addFormatterTest("%v", &pv3, "<**>"+v3s2)
  1282. addFormatterTest("%+v", v3, v3s3)
  1283. addFormatterTest("%+v", pv3, "<*>("+v3Addr+")"+v3s4)
  1284. addFormatterTest("%+v", &pv3, "<**>("+pv3Addr+"->"+v3Addr+")"+v3s4)
  1285. addFormatterTest("%#v", v3, "("+v3t+")"+v3s5)
  1286. addFormatterTest("%#v", pv3, "(*"+v3t+")"+v3s6)
  1287. addFormatterTest("%#v", &pv3, "(**"+v3t+")"+v3s6)
  1288. addFormatterTest("%#+v", v3, "("+v3t+")"+v3s7)
  1289. addFormatterTest("%#+v", pv3, "(*"+v3t+")("+v3Addr+")"+v3s8)
  1290. addFormatterTest("%#+v", &pv3, "(**"+v3t+")("+pv3Addr+"->"+v3Addr+")"+v3s8)
  1291. }
  1292. func addPanicFormatterTests() {
  1293. // Type that panics in its Stringer interface.
  1294. v := panicer(127)
  1295. nv := (*panicer)(nil)
  1296. pv := &v
  1297. vAddr := fmt.Sprintf("%p", pv)
  1298. pvAddr := fmt.Sprintf("%p", &pv)
  1299. vt := "spew_test.panicer"
  1300. vs := "(PANIC=test panic)127"
  1301. addFormatterTest("%v", v, vs)
  1302. addFormatterTest("%v", pv, "<*>"+vs)
  1303. addFormatterTest("%v", &pv, "<**>"+vs)
  1304. addFormatterTest("%v", nv, "<nil>")
  1305. addFormatterTest("%+v", v, vs)
  1306. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  1307. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  1308. addFormatterTest("%+v", nv, "<nil>")
  1309. addFormatterTest("%#v", v, "("+vt+")"+vs)
  1310. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  1311. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  1312. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  1313. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  1314. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  1315. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  1316. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  1317. }
  1318. func addErrorFormatterTests() {
  1319. // Type that has a custom Error interface.
  1320. v := customError(127)
  1321. nv := (*customError)(nil)
  1322. pv := &v
  1323. vAddr := fmt.Sprintf("%p", pv)
  1324. pvAddr := fmt.Sprintf("%p", &pv)
  1325. vt := "spew_test.customError"
  1326. vs := "error: 127"
  1327. addFormatterTest("%v", v, vs)
  1328. addFormatterTest("%v", pv, "<*>"+vs)
  1329. addFormatterTest("%v", &pv, "<**>"+vs)
  1330. addFormatterTest("%v", nv, "<nil>")
  1331. addFormatterTest("%+v", v, vs)
  1332. addFormatterTest("%+v", pv, "<*>("+vAddr+")"+vs)
  1333. addFormatterTest("%+v", &pv, "<**>("+pvAddr+"->"+vAddr+")"+vs)
  1334. addFormatterTest("%+v", nv, "<nil>")
  1335. addFormatterTest("%#v", v, "("+vt+")"+vs)
  1336. addFormatterTest("%#v", pv, "(*"+vt+")"+vs)
  1337. addFormatterTest("%#v", &pv, "(**"+vt+")"+vs)
  1338. addFormatterTest("%#v", nv, "(*"+vt+")"+"<nil>")
  1339. addFormatterTest("%#+v", v, "("+vt+")"+vs)
  1340. addFormatterTest("%#+v", pv, "(*"+vt+")("+vAddr+")"+vs)
  1341. addFormatterTest("%#+v", &pv, "(**"+vt+")("+pvAddr+"->"+vAddr+")"+vs)
  1342. addFormatterTest("%#+v", nv, "(*"+vt+")"+"<nil>")
  1343. }
  1344. func addPassthroughFormatterTests() {
  1345. // %x passthrough with uint.
  1346. v := uint(4294967295)
  1347. pv := &v
  1348. vAddr := fmt.Sprintf("%x", pv)
  1349. pvAddr := fmt.Sprintf("%x", &pv)
  1350. vs := "ffffffff"
  1351. addFormatterTest("%x", v, vs)
  1352. addFormatterTest("%x", pv, vAddr)
  1353. addFormatterTest("%x", &pv, pvAddr)
  1354. // %#x passthrough with uint.
  1355. v2 := int(2147483647)
  1356. pv2 := &v2
  1357. v2Addr := fmt.Sprintf("%#x", pv2)
  1358. pv2Addr := fmt.Sprintf("%#x", &pv2)
  1359. v2s := "0x7fffffff"
  1360. addFormatterTest("%#x", v2, v2s)
  1361. addFormatterTest("%#x", pv2, v2Addr)
  1362. addFormatterTest("%#x", &pv2, pv2Addr)
  1363. // %f passthrough with precision.
  1364. addFormatterTest("%.2f", 3.1415, "3.14")
  1365. addFormatterTest("%.3f", 3.1415, "3.142")
  1366. addFormatterTest("%.4f", 3.1415, "3.1415")
  1367. // %f passthrough with width and precision.
  1368. addFormatterTest("%5.2f", 3.1415, " 3.14")
  1369. addFormatterTest("%6.3f", 3.1415, " 3.142")
  1370. addFormatterTest("%7.4f", 3.1415, " 3.1415")
  1371. // %d passthrough with width.
  1372. addFormatterTest("%3d", 127, "127")
  1373. addFormatterTest("%4d", 127, " 127")
  1374. addFormatterTest("%5d", 127, " 127")
  1375. // %q passthrough with string.
  1376. addFormatterTest("%q", "test", "\"test\"")
  1377. }
  1378. // TestFormatter executes all of the tests described by formatterTests.
  1379. func TestFormatter(t *testing.T) {
  1380. // Setup tests.
  1381. addIntFormatterTests()
  1382. addUintFormatterTests()
  1383. addBoolFormatterTests()
  1384. addFloatFormatterTests()
  1385. addComplexFormatterTests()
  1386. addArrayFormatterTests()
  1387. addSliceFormatterTests()
  1388. addStringFormatterTests()
  1389. addInterfaceFormatterTests()
  1390. addMapFormatterTests()
  1391. addStructFormatterTests()
  1392. addUintptrFormatterTests()
  1393. addUnsafePointerFormatterTests()
  1394. addChanFormatterTests()
  1395. addFuncFormatterTests()
  1396. addCircularFormatterTests()
  1397. addPanicFormatterTests()
  1398. addErrorFormatterTests()
  1399. addPassthroughFormatterTests()
  1400. t.Logf("Running %d tests", len(formatterTests))
  1401. for i, test := range formatterTests {
  1402. buf := new(bytes.Buffer)
  1403. spew.Fprintf(buf, test.format, test.in)
  1404. s := buf.String()
  1405. if testFailed(s, test.wants) {
  1406. t.Errorf("Formatter #%d format: %s got: %s %s", i, test.format, s,
  1407. stringizeWants(test.wants))
  1408. continue
  1409. }
  1410. }
  1411. }
  1412. func TestPrintSortedKeys(t *testing.T) {
  1413. cfg := spew.ConfigState{SortKeys: true}
  1414. s := cfg.Sprint(map[int]string{1: "1", 3: "3", 2: "2"})
  1415. expected := "map[1:1 2:2 3:3]"
  1416. if s != expected {
  1417. t.Errorf("Sorted keys mismatch:\n %v %v", s, expected)
  1418. }
  1419. }