Skip to content

Commit

Permalink
Add a workflow for publishing DocC on every commit
Browse files Browse the repository at this point in the history
  • Loading branch information
danielsaidi committed Mar 5, 2024
1 parent 8a2215c commit cb7dcf9
Show file tree
Hide file tree
Showing 5 changed files with 69 additions and 8 deletions.
8 changes: 4 additions & 4 deletions .github/workflows/swift.yml → .github/workflows/build.yml
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
# This workflow will build a Swift project
# This workflow builds and tests the project.
# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-swift

name: Swift
name: Build Runner

on:
push:
branches: [ "main" ]
branches: ["main"]
pull_request:
branches: [ "main" ]
branches: ["main"]

jobs:
build:
Expand Down
57 changes: 57 additions & 0 deletions .github/workflows/docc.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
# This workflow builds publish DocC docs to GitHub Pages.
# Source: https://maxxfrazer.medium.com/deploying-docc-with-github-actions-218c5ca6cad5
# Sample: https://github.com/AgoraIO-Community/VideoUIKit-iOS/blob/main/.github/workflows/deploy_docs.yml

name: DocC Runner

on:
push:
branches: ["main"]

# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
permissions:
contents: read
pages: write
id-token: write

# Allow one concurrent deployment
concurrency:
group: "pages"
cancel-in-progress: true

jobs:
deploy:
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: macos-13
steps:
- name: Checkout
uses: actions/checkout@v3
- id: pages
name: Setup Pages
uses: actions/configure-pages@v4
- name: Select Xcode 15.1
uses: maxim-lobanov/setup-xcode@v1
with:
xcode-version: '15.1.0'
- name: Build DocC
run: |
swift package resolve;
xcodebuild docbuild -scheme RichTextKit -derivedDataPath /tmp/docbuild -destination 'generic/platform=iOS';
$(xcrun --find docc) process-archive \
transform-for-static-hosting /tmp/docbuild/Build/Products/Debug-iphoneos/RichTextKit.doccarchive \
--output-path docs \
--hosting-base-path RichTextKit;
echo "<script>window.location.href += \"/documentation/richtextkit\"</script>" > docs/index.html;
- name: Upload artifact
uses: actions/upload-pages-artifact@v3
with:
path: 'docs'
- id: deployment
name: Deploy to GitHub Pages
uses: actions/deploy-pages@v4
4 changes: 3 additions & 1 deletion Tests/RichTextKitTests/RichTextContextTests.swift
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,9 @@ final class RichTextContextTests: XCTestCase {

func testInitializerSetsDefaultValues() {
let context = RichTextContext()
XCTAssertEqual(context.fontName, "")
let iosFontName = context.fontName == ".SFUI"
let macFontName = context.fontName == ".AppleSystemUIFont"
XCTAssertTrue(iosFontName || macFontName)
XCTAssertEqual(context.fontSize, 16)
XCTAssertFalse(context.hasStyle(.bold))
XCTAssertFalse(context.hasStyle(.italic))
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,8 @@ final class RichTextViewIntegrationTests: XCTestCase {
// When starting RichTextEditor we want to check if the font and color is set correctly.
textContext.selectRange(.init(location: 0, length: 0))

XCTAssertEqual(attributes[.font] as? FontRepresentable, FontRepresentable.systemFont(ofSize: 16))
let font = attributes[.font] as? FontRepresentable
XCTAssertEqual(font?.pointSize, 16)
XCTAssertEqual(attributes[.foregroundColor] as? ColorRepresentable, ColorRepresentable.label)

// First we fill in the empty textView with some text, select it and set bold and italic to it.
Expand All @@ -76,7 +77,8 @@ final class RichTextViewIntegrationTests: XCTestCase {

textContext.selectRange(.init(location: 0, length: stringWithoutAttributes.count))

XCTAssertEqual(attributes[.font] as? FontRepresentable, FontRepresentable.systemFont(ofSize: 16))
let font = attributes[.font] as? FontRepresentable
XCTAssertEqual(font?.pointSize, 16)
XCTAssertEqual(attributes[.foregroundColor] as? ColorRepresentable, ColorRepresentable.label)

textView.setRichTextStyle(.bold, to: true)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ final class RichTextViewComponentTests: XCTestCase {
XCTAssertTrue(view.allowsEditingTextAttributes)
XCTAssertEqual(view.autocapitalizationType, .sentences)
#endif
XCTAssertEqual(view.backgroundColor, .clear)
XCTAssertNotEqual(view.backgroundColor, .clear)
XCTAssertEqual(view.contentCompressionResistancePriority(for: .horizontal), .defaultLow)
#if iOS
XCTAssertEqual(view.spellCheckingType, .no)
Expand Down

0 comments on commit cb7dcf9

Please sign in to comment.