#  Copyright (C) 2024 The Android Open Source Project
#
#  Licensed 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.

"""NonApiTest decorator."""

from typing import List
from .ReasonType import ReasonType


class NonApiTest(object):
  """Marks the type of CTS test not enforcing API functionalities and behaviors.

  @NonApiTest should be used only after a consultation with ape-relpgm-cls@.

  Args:
    exemption_reasons: the list of reasons for not enforcing API behaviors.
    justification: additional explanation for reason types listed.
  """

  def __init__(
      self, exemption_reasons: List[ReasonType] = [], justification: str = ''
  ):
    self._exemption_reasons = exemption_reasons
    self._justification = justification

  def __call__(self, func):
    return func
