File: InlineContentPlainTextTests.swift

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (186 lines) | stat: -rw-r--r-- 6,947 bytes parent folder | download
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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
/*
 This source file is part of the Swift.org open source project

 Copyright (c) 2021 Apple Inc. and the Swift project authors
 Licensed under Apache License v2.0 with Runtime Library Exception

 See https://swift.org/LICENSE.txt for license information
 See https://swift.org/CONTRIBUTORS.txt for Swift project authors
*/

import XCTest
@testable import SwiftDocC

public class InlineContentPlainTextTests: XCTestCase {
    func testPlainTextFromCodeVoice() {
        let testText = "This text is code voiced."
        
        let codeVoiceContent: [RenderInlineContent] = [
            .codeVoice(code: testText),
        ]
        
        XCTAssertEqual(codeVoiceContent.plainText, testText)
    }
    
    func testPlainTextFromEmphasis() {
        let testText = "This text is emphasized."
        
        let emphasisContent: [RenderInlineContent] = [
            .emphasis(inlineContent: [.text(testText)]),
        ]
        
        XCTAssertEqual(emphasisContent.plainText, testText)
    }
    
    func testPlainTextFromStrong() {
        let testText = "This is strong text."
        
        let strongContent: [RenderInlineContent] = [
            .strong(inlineContent: [.text(testText)]),
        ]
        
        XCTAssertEqual(strongContent.plainText, testText)
    }

    func testPlainTextFromImage() {
        let testText = "This is an image abstract."
        
        let firstImageContent: [RenderInlineContent] = [
            .image(identifier: RenderReferenceIdentifier("id"),
                   metadata: RenderContentMetadata(anchor: nil, title: nil, abstract: [.text(testText)])),
        ]
        
        let secondImageContent: [RenderInlineContent] = [
            .image(identifier: RenderReferenceIdentifier("id"),
                   metadata: RenderContentMetadata(anchor: nil, title: nil, abstract: nil)),
        ]
        
        XCTAssertEqual(firstImageContent.plainText, testText)
        XCTAssertEqual(secondImageContent.plainText, "")
    }
    
    func testPlainTextFromReference() {
        let testText = "This is a reference title."
        
        let firstReferenceContent: [RenderInlineContent] = [
            .reference(identifier: RenderReferenceIdentifier("test"),
                       isActive: true, overridingTitle: testText, overridingTitleInlineContent: [.text(testText)]),
        ]
        
        let secondReferenceContent: [RenderInlineContent] = [
            .reference(identifier: RenderReferenceIdentifier("test"),
                       isActive: true, overridingTitle: testText, overridingTitleInlineContent: nil),
        ]
        
        let thirdReferenceContent: [RenderInlineContent] = [
            .reference(identifier: RenderReferenceIdentifier("test"),
                       isActive: true, overridingTitle: nil, overridingTitleInlineContent: [.text(testText)]),
        ]
        
        let fourthReferenceContent: [RenderInlineContent] = [
            .reference(identifier: RenderReferenceIdentifier("test"),
                       isActive: true, overridingTitle: nil, overridingTitleInlineContent: nil),
        ]
        
        XCTAssertEqual(firstReferenceContent.plainText, testText)
        XCTAssertEqual(secondReferenceContent.plainText, testText)
        XCTAssertEqual(thirdReferenceContent.plainText, testText)
        XCTAssertEqual(fourthReferenceContent.plainText, "")
    }
    
    func testPlainTextFromText() {
        let testText = "This is plain text."
        
        let textContent: [RenderInlineContent] = [
            .text(testText),
        ]
        
        XCTAssertEqual(textContent.plainText, testText)
    }
    
    func testPlainTextFromNewTerm() {
        let testText = "This is a new term."
        
        let newTermContent: [RenderInlineContent] = [
            .newTerm(inlineContent: [.text(testText)]),
        ]
        
        XCTAssertEqual(newTermContent.plainText, testText)
    }
    
    func testPlainTextFromInlineHeader() {
        let testText = "This is an inline header."
        
        let inlineHeadContent: [RenderInlineContent] = [
            .inlineHead(inlineContent: [.text(testText)]),
        ]
        
        XCTAssertEqual(inlineHeadContent.plainText, testText)
    }
    
    func testPlainTextFromSubscript() {
        let testText = "This is a subscript."
        
        let subscriptContent: [RenderInlineContent] = [
            .subscript(inlineContent: [.text(testText)]),
        ]
        
        XCTAssertEqual(subscriptContent.plainText, testText)
    }
    
    func testPlainTextFromSuperscript() {
        let testText = "This is a superscript."
        
        let superscriptContent: [RenderInlineContent] = [
            .superscript(inlineContent: [.text(testText)]),
        ]
        
        XCTAssertEqual(superscriptContent.plainText, testText)
    }
    
    func testPlainTextFromMixed() {
        let basicMixedContent: [RenderInlineContent] = [
            .codeVoice(code: "This is code."),
            .text(" "),
            .emphasis(inlineContent: [.text("This is emphasized.")]),
            .text(" "),
            .strong(inlineContent: [.text("This is strong.")]),
            .text(" "),
            .text("This is text."),
            .text(" "),
            .newTerm(inlineContent: [.text("This is a new term.")]),
            .text(" "),
            .inlineHead(inlineContent: [.text("This is an inline header.")]),
            .text(" "),
            .subscript(inlineContent: [.text("This is a subscript.")]),
            .text(" "),
            .superscript(inlineContent: [.text("This is a superscript.")]),
        ]
        
        let expectedBasicText = "This is code. This is emphasized. This is strong. This is text. This is a new term. This is an inline header. This is a subscript. This is a superscript."
        
        XCTAssertEqual(basicMixedContent.plainText, expectedBasicText)
        
        let complicatedMixedContent: [RenderInlineContent] = [
            .codeVoice(code: basicMixedContent.plainText),
            .text(" "),
            .emphasis(inlineContent: basicMixedContent),
            .text(" "),
            .strong(inlineContent: basicMixedContent),
            .text(" "),
            .text(basicMixedContent.plainText),
            .text(" "),
            .newTerm(inlineContent: basicMixedContent),
            .text(" "),
            .inlineHead(inlineContent: basicMixedContent),
            .text(" "),
            .subscript(inlineContent: basicMixedContent),
            .text(" "),
            .superscript(inlineContent: basicMixedContent),
        ]
        
        let expectedComplicatedText = "\(expectedBasicText) \(expectedBasicText) \(expectedBasicText) \(expectedBasicText) \(expectedBasicText) \(expectedBasicText) \(expectedBasicText) \(expectedBasicText)"
        
        XCTAssertEqual(complicatedMixedContent.plainText, expectedComplicatedText)
    }
}