|
5 | 5 | "testing" |
6 | 6 |
|
7 | 7 | . "github.com/yuin/goldmark" |
| 8 | + "github.com/yuin/goldmark/ast" |
8 | 9 | "github.com/yuin/goldmark/testutil" |
9 | 10 | "github.com/yuin/goldmark/text" |
10 | 11 | ) |
@@ -202,3 +203,92 @@ func TestASTInlineNodeText(t *testing.T) { |
202 | 203 | } |
203 | 204 |
|
204 | 205 | } |
| 206 | + |
| 207 | +func TestHasBlankPreviousLines(t *testing.T) { |
| 208 | + var cases = []struct { |
| 209 | + Name string |
| 210 | + Source string |
| 211 | + Node func(n ast.Node) ast.Node |
| 212 | + Expected bool |
| 213 | + }{ |
| 214 | + { |
| 215 | + Name: "nesting paragraphs in blockquotes", |
| 216 | + Source: ` |
| 217 | +> a |
| 218 | +> |
| 219 | +> b |
| 220 | +`, |
| 221 | + Node: func(n ast.Node) ast.Node { |
| 222 | + return n.FirstChild().FirstChild().NextSibling() |
| 223 | + }, |
| 224 | + Expected: true, |
| 225 | + }, |
| 226 | + { |
| 227 | + Name: "nesting HTML blocks in blockquotes", |
| 228 | + Source: ` |
| 229 | +> <!-- a --> |
| 230 | +> |
| 231 | +> <!-- b --> |
| 232 | +`, |
| 233 | + Node: func(n ast.Node) ast.Node { |
| 234 | + return n.FirstChild().FirstChild().NextSibling() |
| 235 | + }, |
| 236 | + Expected: true, |
| 237 | + }, |
| 238 | + { |
| 239 | + Name: "nesting HTML blocks in blockquotes", |
| 240 | + Source: ` |
| 241 | +> <!-- a --> |
| 242 | +> <!-- b --> |
| 243 | +`, |
| 244 | + Node: func(n ast.Node) ast.Node { |
| 245 | + return n.FirstChild().FirstChild().NextSibling() |
| 246 | + }, |
| 247 | + Expected: false, |
| 248 | + }, |
| 249 | + { |
| 250 | + Name: "nesting loose lists in blockquotes", |
| 251 | + Source: ` |
| 252 | +> - a |
| 253 | +> |
| 254 | +> - b |
| 255 | +`, |
| 256 | + Node: func(n ast.Node) ast.Node { |
| 257 | + return n.FirstChild().FirstChild().FirstChild().NextSibling() |
| 258 | + }, |
| 259 | + Expected: true, |
| 260 | + }, |
| 261 | + { |
| 262 | + Name: "nesting tight lists in blockquotes", |
| 263 | + Source: ` |
| 264 | +> - a |
| 265 | +> - b |
| 266 | +`, |
| 267 | + Node: func(n ast.Node) ast.Node { |
| 268 | + return n.FirstChild().FirstChild().FirstChild().NextSibling() |
| 269 | + }, |
| 270 | + Expected: false, |
| 271 | + }, |
| 272 | + { |
| 273 | + Name: "nesting paragraphs in lists", |
| 274 | + Source: ` |
| 275 | +- a |
| 276 | +
|
| 277 | + b |
| 278 | +`, |
| 279 | + Node: func(n ast.Node) ast.Node { |
| 280 | + return n.FirstChild().FirstChild().FirstChild().NextSibling() |
| 281 | + }, |
| 282 | + Expected: true, |
| 283 | + }, |
| 284 | + } |
| 285 | + md := New() |
| 286 | + for _, cs := range cases { |
| 287 | + t.Run(cs.Name, func(t *testing.T) { |
| 288 | + n := md.Parser().Parse(text.NewReader([]byte(cs.Source))) |
| 289 | + if cs.Node(n).HasBlankPreviousLines() != cs.Expected { |
| 290 | + t.Errorf("expected %v, got %v", cs.Expected, !cs.Expected) |
| 291 | + } |
| 292 | + }) |
| 293 | + } |
| 294 | +} |
0 commit comments