blob: fe2b56c6b3eb08bf1ac75cfee40c841f964eb6f2 [file] [log] [blame] [edit]
// <copyright file="UnhandledAlertException.cs" company="WebDriver Committers">
// Licensed to the Software Freedom Conservancy (SFC) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The SFC licenses this file
// to you under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// </copyright>
using System;
using System.Runtime.Serialization;
namespace OpenQA.Selenium
{
/// <summary>
/// The exception that is thrown when an unhandled alert is present.
/// </summary>
[Serializable]
public class UnhandledAlertException : WebDriverException
{
private string alertText;
/// <summary>
/// Initializes a new instance of the <see cref="UnhandledAlertException"/> class.
/// </summary>
public UnhandledAlertException()
: base()
{
}
/// <summary>
/// Initializes a new instance of the <see cref="UnhandledAlertException"/> class with
/// a specified error message.
/// </summary>
/// <param name="message">The message that describes the error.</param>
public UnhandledAlertException(string message)
: base(message)
{
}
/// <summary>
/// Initializes a new instance of the <see cref="UnhandledAlertException"/> class with
/// a specified error message and alert text.
/// </summary>
/// <param name="message">The message that describes the error.</param>
/// <param name="alertText">The text of the unhandled alert.</param>
public UnhandledAlertException(string message, string alertText)
: base(message)
{
this.alertText = alertText;
}
/// <summary>
/// Initializes a new instance of the <see cref="UnhandledAlertException"/> class with
/// a specified error message and a reference to the inner exception that is the
/// cause of this exception.
/// </summary>
/// <param name="message">The error message that explains the reason for the exception.</param>
/// <param name="innerException">The exception that is the cause of the current exception,
/// or <see langword="null"/> if no inner exception is specified.</param>
public UnhandledAlertException(string message, Exception innerException)
: base(message, innerException)
{
}
/// <summary>
/// Initializes a new instance of the <see cref="UnhandledAlertException"/> class with serialized data.
/// </summary>
/// <param name="info">The <see cref="SerializationInfo"/> that holds the serialized
/// object data about the exception being thrown.</param>
/// <param name="context">The <see cref="StreamingContext"/> that contains contextual
/// information about the source or destination.</param>
protected UnhandledAlertException(SerializationInfo info, StreamingContext context)
: base(info, context)
{
}
/// <summary>
/// Gets the text of the unhandled alert.
/// </summary>
public string AlertText
{
get { return this.alertText; }
}
/// <summary>
/// Populates a SerializationInfo with the data needed to serialize the target object.
/// </summary>
/// <param name="info">The <see cref="SerializationInfo"/> that holds the serialized
/// object data about the exception being thrown.</param>
/// <param name="context">The <see cref="StreamingContext"/> that contains contextual
/// information about the source or destination.</param>
public override void GetObjectData(SerializationInfo info, StreamingContext context)
{
base.GetObjectData(info, context);
}
}
}