Implemented the CreateFolderEndpoint endpoint.
This commit is contained in:
parent
01d060d583
commit
a594e75712
@ -0,0 +1,54 @@
|
||||
//
|
||||
// CreateFolderEndpoint.swift
|
||||
// APIService
|
||||
//
|
||||
// Created by Javier Cicchelli on 04/12/2022.
|
||||
// Copyright © 2022 Röck+Cöde. All rights reserved.
|
||||
//
|
||||
|
||||
import Foundation
|
||||
|
||||
struct CreateFolderEndpoint: Endpoint {
|
||||
let path: String
|
||||
let method: RequestMethod
|
||||
let credentials: BasicCredentials
|
||||
let headers: [String : String]
|
||||
let body: Data?
|
||||
}
|
||||
|
||||
// MARK: - Initialisers
|
||||
|
||||
extension CreateFolderEndpoint {
|
||||
init(
|
||||
itemId: String,
|
||||
folderName: String,
|
||||
username: String,
|
||||
password: String
|
||||
) {
|
||||
self.path = .init(format: .Formats.itemsWithId, itemId)
|
||||
self.method = .post
|
||||
self.credentials = .init(
|
||||
username: username,
|
||||
password: password
|
||||
)
|
||||
self.headers = [.Header.Keys.contentType: .Header.Values.contentTypeJSON]
|
||||
self.body = {
|
||||
let encoder = JSONEncoder()
|
||||
let folder = Folder(name: folderName)
|
||||
|
||||
do {
|
||||
return try encoder.encode(folder)
|
||||
} catch {
|
||||
return nil
|
||||
}
|
||||
}()
|
||||
}
|
||||
}
|
||||
|
||||
// MARK: - Models
|
||||
|
||||
private extension CreateFolderEndpoint {
|
||||
struct Folder: Encodable {
|
||||
let name: String
|
||||
}
|
||||
}
|
@ -0,0 +1,79 @@
|
||||
//
|
||||
// CreateFolderEndpoint+InitTests.swift
|
||||
// APIServiceTests
|
||||
//
|
||||
// Created by Javier Cicchelli on 04/12/2022.
|
||||
// Copyright © 2022 Röck+Cöde. All rights reserved.
|
||||
//
|
||||
|
||||
import Foundation
|
||||
import XCTest
|
||||
|
||||
@testable import APIService
|
||||
|
||||
final class CreateFolderEndpointInitTests: XCTestCase {
|
||||
|
||||
// MARK: Properties
|
||||
|
||||
let itemId = UUID().uuidString
|
||||
|
||||
var endpoint: CreateFolderEndpoint!
|
||||
var folderName: String!
|
||||
var username: String!
|
||||
var password: String!
|
||||
|
||||
// MARK: Test cases
|
||||
|
||||
func test_withItemId_someFolderName_andProperUsernameAndPassword() throws {
|
||||
// GIVEN
|
||||
folderName = "some-folder"
|
||||
username = "username"
|
||||
password = "password"
|
||||
|
||||
// WHEN
|
||||
endpoint = .init(
|
||||
itemId: itemId,
|
||||
folderName: folderName,
|
||||
username: username,
|
||||
password: password
|
||||
)
|
||||
|
||||
// THEN
|
||||
XCTAssertEqual(endpoint.scheme, .Schemes.http)
|
||||
XCTAssertEqual(endpoint.host, .Hosts.default)
|
||||
XCTAssertEqual(endpoint.path, "/items/\(itemId)")
|
||||
XCTAssertEqual(endpoint.method, .post)
|
||||
XCTAssertEqual(endpoint.credentials.username, username)
|
||||
XCTAssertEqual(endpoint.credentials.password, password)
|
||||
XCTAssertEqual(endpoint.headers, [.Header.Keys.contentType: .Header.Values.contentTypeJSON])
|
||||
XCTAssertEqual(endpoint.authorizationHeader, [.Header.Keys.authorization: "Basic dXNlcm5hbWU6cGFzc3dvcmQ="])
|
||||
XCTAssertEqual(endpoint.body, "{\"name\":\"some-folder\"}".data(using: .utf8))
|
||||
}
|
||||
|
||||
func test_withItemId_someFolderName_andEmptyUsernameOrPassword() throws {
|
||||
// GIVEN
|
||||
folderName = "some-folder"
|
||||
username = ""
|
||||
password = "password"
|
||||
|
||||
// WHEN
|
||||
endpoint = .init(
|
||||
itemId: itemId,
|
||||
folderName: folderName,
|
||||
username: username,
|
||||
password: password
|
||||
)
|
||||
|
||||
// THEN
|
||||
XCTAssertEqual(endpoint.scheme, .Schemes.http)
|
||||
XCTAssertEqual(endpoint.host, .Hosts.default)
|
||||
XCTAssertEqual(endpoint.path, "/items/\(itemId)")
|
||||
XCTAssertEqual(endpoint.method, .post)
|
||||
XCTAssertEqual(endpoint.credentials.username, username)
|
||||
XCTAssertEqual(endpoint.credentials.password, password)
|
||||
XCTAssertEqual(endpoint.headers, [.Header.Keys.contentType: .Header.Values.contentTypeJSON])
|
||||
XCTAssertEqual(endpoint.authorizationHeader, [:])
|
||||
XCTAssertEqual(endpoint.body, "{\"name\":\"some-folder\"}".data(using: .utf8))
|
||||
}
|
||||
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user