// RUN: %empty-directory(%t) // RUN: %target-swift-frontend-emit-module -emit-module-path %t/FakeDistributedActorSystems.swiftmodule -module-name FakeDistributedActorSystems -target %target-swift-5.7-abi-triple %S/Inputs/FakeDistributedActorSystems.swift // RUN: %target-swift-frontend -typecheck -verify -verify-ignore-unknown -target %target-swift-5.7-abi-triple -I %t 2>&1 %s // REQUIRES: concurrency // REQUIRES: distributed import Distributed import FakeDistributedActorSystems struct NotCodable {} protocol NoSerializationRequirementYet: DistributedActor { distributed func test() -> NotCodable // OK, no serialization requirement yet distributed func testAT() async throws -> NotCodable } distributed actor SpecifyRequirement: NoSerializationRequirementYet { typealias ActorSystem = FakeActorSystem // expected-error@+1{{result type 'NotCodable' of distributed instance method 'test' does not conform to serialization requirement 'Codable'}} distributed func test() -> NotCodable { .init() } // expected-error@+1{{result type 'NotCodable' of distributed instance method 'testAT' does not conform to serialization requirement 'Codable'}} distributed func testAT() async throws -> NotCodable { .init() } } protocol ProtocolWithChecksSystem: DistributedActor where ActorSystem == FakeActorSystem { // expected-error@+1{{result type 'NotCodable' of distributed instance method 'testAT' does not conform to serialization requirement 'Codable'}} distributed func testAT() async throws -> NotCodable } distributed actor ProtocolWithChecksSystemDA: ProtocolWithChecksSystem { // expected-error@+1{{result type 'NotCodable' of distributed instance method 'testAT' does not conform to serialization requirement 'Codable'}} distributed func testAT() async throws -> NotCodable { .init() } } protocol ProtocolWithChecksSeqReq: DistributedActor where Self.SerializationRequirement == Codable { // expected-error@+1{{result type 'NotCodable' of distributed instance method 'testAT' does not conform to serialization requirement 'Codable'}} distributed func testAT() async throws -> NotCodable } distributed actor ProtocolWithChecksSeqReqDA_MissingSystem: ProtocolWithChecksSeqReq { // expected-error@-1{{distributed actor 'ProtocolWithChecksSeqReqDA_MissingSystem' does not declare ActorSystem it can be used with}} // expected-note@-2{{you can provide a module-wide default actor system by declaring:}} // // expected-error@-4{{distributed actor 'ProtocolWithChecksSeqReqDA_MissingSystem' does not declare ActorSystem it can be used with}} // // expected-error@-6{{type 'ProtocolWithChecksSeqReqDA_MissingSystem' does not conform to protocol 'DistributedActor'}} // expected-note@-7 {{add stubs for conformance}} // Entire conformance is doomed, so we didn't proceed to checking the functions; that's fine distributed func testAT() async throws -> NotCodable { .init() } } distributed actor ProtocolWithChecksSeqReqDA: ProtocolWithChecksSeqReq { typealias ActorSystem = FakeActorSystem // ok, since FakeActorSystem.SerializationRequirement == ProtocolWithChecksSeqReq.SerializationRequirement // expected-error@+1{{result type 'NotCodable' of distributed instance method 'testAT' does not conform to serialization requirement 'Codable'}} distributed func testAT() async throws -> NotCodable { .init() } } extension NoSerializationRequirementYet { // Still OK, we don't know if this will be implementable or not distributed func test2() -> NotCodable { .init() } } extension NoSerializationRequirementYet where SerializationRequirement == Codable { // expected-error@+1{{result type 'NotCodable' of distributed instance method 'test3' does not conform to serialization requirement 'Codable'}} distributed func test3() -> NotCodable { .init() } } extension NoSerializationRequirementYet where SerializationRequirement: Codable { // expected-error@+1{{result type 'NotCodable' of distributed instance method 'test4' does not conform to serialization requirement 'Codable'}} distributed func test4() -> NotCodable { .init() } } extension ProtocolWithChecksSeqReqDA { // expected-error@+1{{result type 'NotCodable' of distributed instance method 'test4' does not conform to serialization requirement 'Codable'}} distributed func test4() -> NotCodable { .init() } } protocol Recipient: DistributedActor where ActorSystem == FakeActorSystem { associatedtype Info: Sendable & Codable // is Codable, should be ok distributed var info: Info { get async } distributed func getInfo() -> Info } distributed actor RecipientImpl: Recipient { typealias Info = String distributed var info: Info { "info" } distributed func getInfo() -> Info { "info" } } // FIXME(distributed): remove the -verify-ignore-unknown // :0: error: unexpected error produced: instance method 'recordReturnType' requires that 'NotCodable' conform to 'Decodable' // :0: error: unexpected error produced: instance method 'recordReturnType' requires that 'NotCodable' conform to 'Encodable' // :0: error: unexpected error produced: instance method 'remoteCall(on:target:invocation:throwing:returning:)' requires that 'NotCodable' conform to 'Decodable' // :0: error: unexpected error produced: instance method 'remoteCall(on:target:invocation:throwing:returning:)' requires that 'NotCodable' conform to 'Encodable'