pub struct XCTAttachment { /* private fields */ }Expand description
Represents the concept of data attached to an XCTActivity. Allows reporting more context about the test run for debugging, such as screenshots, log files, and configuration dictionaries.
Each attachment must be added to an activity to be handed off to XCTest. There are two ways to get an activity:
- XCTestCase conforms to the XCTActivity protocol, attachments can be added to it directly.
- Create a nested activity with +[XCTContext runActivityNamed:block:], the parameter inside the block is a new activity to which attachments can be added.
Once you have an XCTActivity-conforming object:
• Create a new XCTAttachment with one of the initializers provided.
• Optionally customize the attachment’s lifetime, name and userInfo properties.
• Add the attachment to the activity with -[XCTActivity addAttachment:].
- (void)testFoo
{
// ...
NSString *logs = ...
XCTAttachment *attachment = [XCTAttachment attachmentWithString:logs];
attachment.name = @"Build logs";
[self addAttachment:attachment];
}
- (void)testNestedFoo
{
// ...
[XCTContext runActivityNamed:@"Collect logs" block:^(id<XCTActivity> activity){
NSString *logs = ...
XCTAttachment *attachment = [XCTAttachment attachmentWithString:logs];
attachment.name = @"Build logs";
[activity addAttachment:attachment];
}];
}
Attachments have the default lifetime of .deleteOnSuccess, which means they are deleted when
their test passes. This ensures attachments are only kept when test fails. To override this
behavior, change the value of the lifetime property to .keepAlways before adding it to an activity.
- (void)testImportantAttachment
{
XCTAttachment *attachment = ...
attachment.lifetime = XCTAttachmentLifetimeKeepAlways;
[self addAttachment:attachment];
}
See also Apple’s documentation
Implementations§
Source§impl XCTAttachment
impl XCTAttachment
pub unsafe fn new() -> Retained<Self>
pub unsafe fn init(this: Allocated<Self>) -> Retained<Self>
Sourcepub unsafe fn initWithUniformTypeIdentifier_name_payload_userInfo(
this: Allocated<Self>,
identifier: Option<&NSString>,
name: Option<&NSString>,
payload: Option<&NSData>,
user_info: Option<&NSDictionary>,
) -> Retained<Self>
pub unsafe fn initWithUniformTypeIdentifier_name_payload_userInfo( this: Allocated<Self>, identifier: Option<&NSString>, name: Option<&NSString>, payload: Option<&NSData>, user_info: Option<&NSDictionary>, ) -> Retained<Self>
§Safety
user_info generic should be of the correct type.
Sourcepub unsafe fn attachmentWithUniformTypeIdentifier_name_payload_userInfo(
identifier: Option<&NSString>,
name: Option<&NSString>,
payload: Option<&NSData>,
user_info: Option<&NSDictionary>,
) -> Retained<Self>
pub unsafe fn attachmentWithUniformTypeIdentifier_name_payload_userInfo( identifier: Option<&NSString>, name: Option<&NSString>, payload: Option<&NSData>, user_info: Option<&NSDictionary>, ) -> Retained<Self>
§Safety
user_info generic should be of the correct type.
Sourcepub fn uniformTypeIdentifier(&self) -> Retained<NSString>
pub fn uniformTypeIdentifier(&self) -> Retained<NSString>
Uniform Type Identifier of the payload data. Examples: “public.png”, “public.jpeg”, “public.plain-text”, “public.data”, “com.apple.xml-property-list”.
Sourcepub fn userInfo(&self) -> Option<Retained<NSDictionary>>
pub fn userInfo(&self) -> Option<Retained<NSDictionary>>
Container for additional metadata, such as pixel density with images.
Sourcepub unsafe fn setUserInfo(&self, user_info: Option<&NSDictionary>)
pub unsafe fn setUserInfo(&self, user_info: Option<&NSDictionary>)
pub fn lifetime(&self) -> XCTAttachmentLifetime
Sourcepub fn setLifetime(&self, lifetime: XCTAttachmentLifetime)
pub fn setLifetime(&self, lifetime: XCTAttachmentLifetime)
Setter for lifetime.
Source§impl XCTAttachment
ConvenienceInitializers.
impl XCTAttachment
ConvenienceInitializers.
Sourcepub fn attachmentWithData(payload: &NSData) -> Retained<Self>
pub fn attachmentWithData(payload: &NSData) -> Retained<Self>
Creates a new data attachment (type “public.data”) with the specified payload.
Sourcepub fn attachmentWithData_uniformTypeIdentifier(
payload: &NSData,
identifier: &NSString,
) -> Retained<Self>
pub fn attachmentWithData_uniformTypeIdentifier( payload: &NSData, identifier: &NSString, ) -> Retained<Self>
Creates a new attachment with the specified payload and type.
Sourcepub fn attachmentWithString(string: &NSString) -> Retained<Self>
pub fn attachmentWithString(string: &NSString) -> Retained<Self>
Creates a new plain UTF-8 encoded text attachment (type “public.plain-text”) with the specified string.
Sourcepub unsafe fn attachmentWithArchivableObject(
object: &ProtocolObject<dyn NSSecureCoding>,
) -> Retained<Self>
pub unsafe fn attachmentWithArchivableObject( object: &ProtocolObject<dyn NSSecureCoding>, ) -> Retained<Self>
Creates an attachment with an object that can be encoded with NSSecureCoding. Defaults to type “public.data”.
§Safety
object should be of the correct type.
Sourcepub unsafe fn attachmentWithArchivableObject_uniformTypeIdentifier(
object: &ProtocolObject<dyn NSSecureCoding>,
identifier: &NSString,
) -> Retained<Self>
pub unsafe fn attachmentWithArchivableObject_uniformTypeIdentifier( object: &ProtocolObject<dyn NSSecureCoding>, identifier: &NSString, ) -> Retained<Self>
Creates an attachment with an object that can be encoded with NSSecureCoding and type.
§Safety
object should be of the correct type.
Sourcepub unsafe fn attachmentWithPlistObject(object: &AnyObject) -> Retained<Self>
pub unsafe fn attachmentWithPlistObject(object: &AnyObject) -> Retained<Self>
Creates an attachment with an object that can be encoded into an XML property list.
§Safety
object should be of the correct type.
Sourcepub fn attachmentWithContentsOfFileAtURL(url: &NSURL) -> Retained<Self>
pub fn attachmentWithContentsOfFileAtURL(url: &NSURL) -> Retained<Self>
Creates an attachment with an existing file on disk. Attachment’s uniform type identifier is inferred from the file extension. If no type can be inferred from the extension, fallback is “public.data”.
Note: Only works for files, not directories.
Sourcepub fn attachmentWithContentsOfFileAtURL_uniformTypeIdentifier(
url: &NSURL,
identifier: &NSString,
) -> Retained<Self>
pub fn attachmentWithContentsOfFileAtURL_uniformTypeIdentifier( url: &NSURL, identifier: &NSString, ) -> Retained<Self>
Creates an attachment with an existing file on disk and type.
Note: Only works for files, not directories.
Sourcepub fn attachmentWithCompressedContentsOfDirectoryAtURL(
url: &NSURL,
) -> Retained<Self>
pub fn attachmentWithCompressedContentsOfDirectoryAtURL( url: &NSURL, ) -> Retained<Self>
Creates an attachment with an existing directory on disk. Automatically zips the directory, the content type is “public.zip-archive”.
pub fn attachmentWithImage(image: &NSImage) -> Retained<Self>
objc2-app-kit and macOS only.pub fn attachmentWithImage_quality( image: &NSImage, quality: XCTImageQuality, ) -> Retained<Self>
objc2-app-kit and macOS only.Source§impl XCTAttachment
XCUIScreenshot_ConvenienceInitializers.
impl XCTAttachment
XCUIScreenshot_ConvenienceInitializers.
Sourcepub fn attachmentWithScreenshot(screenshot: &XCUIScreenshot) -> Retained<Self>
Available on crate feature objc2-xc-ui-automation only.
pub fn attachmentWithScreenshot(screenshot: &XCUIScreenshot) -> Retained<Self>
objc2-xc-ui-automation only.Creates an attachment with a screenshot and the specified quality.
Sourcepub fn attachmentWithScreenshot_quality(
screenshot: &XCUIScreenshot,
quality: XCTImageQuality,
) -> Retained<Self>
Available on crate feature objc2-xc-ui-automation only.
pub fn attachmentWithScreenshot_quality( screenshot: &XCUIScreenshot, quality: XCTImageQuality, ) -> Retained<Self>
objc2-xc-ui-automation only.Creates an attachment with a screenshot and the specified quality.
Methods from Deref<Target = NSObject>§
Sourcepub fn doesNotRecognizeSelector(&self, sel: Sel) -> !
pub fn doesNotRecognizeSelector(&self, sel: Sel) -> !
Handle messages the object doesn’t recognize.
See Apple’s documentation for details.
Methods from Deref<Target = AnyObject>§
Sourcepub fn class(&self) -> &'static AnyClass
pub fn class(&self) -> &'static AnyClass
Dynamically find the class of this object.
§Panics
May panic if the object is invalid (which may be the case for objects
returned from unavailable init/new methods).
§Example
Check that an instance of NSObject has the precise class NSObject.
use objc2::ClassType;
use objc2::runtime::NSObject;
let obj = NSObject::new();
assert_eq!(obj.class(), NSObject::class());Sourcepub unsafe fn get_ivar<T>(&self, name: &str) -> &Twhere
T: Encode,
👎Deprecated: this is difficult to use correctly, use Ivar::load instead.
pub unsafe fn get_ivar<T>(&self, name: &str) -> &Twhere
T: Encode,
Ivar::load instead.Use Ivar::load instead.
§Safety
The object must have an instance variable with the given name, and it
must be of type T.
See Ivar::load_ptr for details surrounding this.
Sourcepub fn downcast_ref<T>(&self) -> Option<&T>where
T: DowncastTarget,
pub fn downcast_ref<T>(&self) -> Option<&T>where
T: DowncastTarget,
Attempt to downcast the object to a class of type T.
This is the reference-variant. Use Retained::downcast if you want
to convert a retained object to another type.
§Mutable classes
Some classes have immutable and mutable variants, such as NSString
and NSMutableString.
When some Objective-C API signature says it gives you an immutable class, it generally expects you to not mutate that, even though it may technically be mutable “under the hood”.
So using this method to convert a NSString to a NSMutableString,
while not unsound, is generally frowned upon unless you created the
string yourself, or the API explicitly documents the string to be
mutable.
See Apple’s documentation on mutability and on
isKindOfClass: for more details.
§Generic classes
Objective-C generics are called “lightweight generics”, and that’s because they aren’t exposed in the runtime. This makes it impossible to safely downcast to generic collections, so this is disallowed by this method.
You can, however, safely downcast to generic collections where all the
type-parameters are AnyObject.
§Panics
This works internally by calling isKindOfClass:. That means that the
object must have the instance method of that name, and an exception
will be thrown (if CoreFoundation is linked) or the process will abort
if that is not the case. In the vast majority of cases, you don’t need
to worry about this, since both root objects NSObject and
NSProxy implement this method.
§Examples
Cast an NSString back and forth from NSObject.
use objc2::rc::Retained;
use objc2_foundation::{NSObject, NSString};
let obj: Retained<NSObject> = NSString::new().into_super();
let string = obj.downcast_ref::<NSString>().unwrap();
// Or with `downcast`, if we do not need the object afterwards
let string = obj.downcast::<NSString>().unwrap();Try (and fail) to cast an NSObject to an NSString.
use objc2_foundation::{NSObject, NSString};
let obj = NSObject::new();
assert!(obj.downcast_ref::<NSString>().is_none());Try to cast to an array of strings.
use objc2_foundation::{NSArray, NSObject, NSString};
let arr = NSArray::from_retained_slice(&[NSObject::new()]);
// This is invalid and doesn't type check.
let arr = arr.downcast_ref::<NSArray<NSString>>();This fails to compile, since it would require enumerating over the array to ensure that each element is of the desired type, which is a performance pitfall.
Downcast when processing each element instead.
use objc2_foundation::{NSArray, NSObject, NSString};
let arr = NSArray::from_retained_slice(&[NSObject::new()]);
for elem in arr {
if let Some(data) = elem.downcast_ref::<NSString>() {
// handle `data`
}
}Trait Implementations§
Source§impl AsRef<AnyObject> for XCTAttachment
impl AsRef<AnyObject> for XCTAttachment
Source§impl AsRef<NSObject> for XCTAttachment
impl AsRef<NSObject> for XCTAttachment
Source§impl AsRef<XCTAttachment> for XCTAttachment
impl AsRef<XCTAttachment> for XCTAttachment
Source§impl Borrow<AnyObject> for XCTAttachment
impl Borrow<AnyObject> for XCTAttachment
Source§impl Borrow<NSObject> for XCTAttachment
impl Borrow<NSObject> for XCTAttachment
Source§impl ClassType for XCTAttachment
impl ClassType for XCTAttachment
Source§const NAME: &'static str = "XCTAttachment"
const NAME: &'static str = "XCTAttachment"
Source§type ThreadKind = <<XCTAttachment as ClassType>::Super as ClassType>::ThreadKind
type ThreadKind = <<XCTAttachment as ClassType>::Super as ClassType>::ThreadKind
Source§impl Debug for XCTAttachment
impl Debug for XCTAttachment
Source§impl Deref for XCTAttachment
impl Deref for XCTAttachment
Source§impl Hash for XCTAttachment
impl Hash for XCTAttachment
Source§impl Message for XCTAttachment
impl Message for XCTAttachment
Source§impl NSCoding for XCTAttachment
impl NSCoding for XCTAttachment
Source§impl NSObjectProtocol for XCTAttachment
impl NSObjectProtocol for XCTAttachment
Source§fn isEqual(&self, other: Option<&AnyObject>) -> bool
fn isEqual(&self, other: Option<&AnyObject>) -> bool
Source§fn hash(&self) -> usize
fn hash(&self) -> usize
Source§fn isKindOfClass(&self, cls: &AnyClass) -> bool
fn isKindOfClass(&self, cls: &AnyClass) -> bool
Source§fn is_kind_of<T>(&self) -> bool
fn is_kind_of<T>(&self) -> bool
isKindOfClass directly, or cast your objects with AnyObject::downcast_ref