1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110
|
# Licensed to Elasticsearch B.V. under one or more contributor
# license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright
# ownership. Elasticsearch B.V. 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.
import warnings
import pytest
from elasticsearch._sync.client.utils import (
Stability,
Visibility,
_availability_warning,
_quote,
)
from elasticsearch.exceptions import GeneralAvailabilityWarning
def test_handles_ascii():
string = "abc123"
assert "abc123" == _quote(string)
def test_handles_bytestring():
string = b"celery-task-meta-c4f1201f-eb7b-41d5-9318-a75a8cfbdaa0"
assert string.decode() == _quote(string)
def test_handles_unicode():
assert "some-index-type-%E4%B8%AD%E6%96%87" == _quote("some-index-type-中文")
def test_handles_unicode2():
string = "中*文,"
assert "%E4%B8%AD*%E6%96%87," == _quote(string)
class TestAvailabilityWarning:
def test_default(self):
@_availability_warning(stability=Stability.STABLE)
def func_default(*args, **kwargs):
pass
with warnings.catch_warnings():
warnings.simplefilter("error")
func_default()
def test_beta(self, recwarn):
@_availability_warning(stability=Stability.BETA)
def func_beta(*args, **kwargs):
pass
with pytest.warns(
GeneralAvailabilityWarning,
match="This API is in beta and is subject to change.",
):
func_beta()
def test_experimental(self, recwarn):
@_availability_warning(stability=Stability.EXPERIMENTAL)
def func_experimental(*args, **kwargs):
pass
with pytest.warns(
GeneralAvailabilityWarning,
match="This API is in technical preview and may be changed or removed in a future release.",
):
func_experimental()
def test_private(self, recwarn):
@_availability_warning(
stability=Stability.STABLE, visibility=Visibility.PRIVATE
)
def func_private(*args, **kwargs):
pass
with pytest.warns(
GeneralAvailabilityWarning,
match="This API is private.",
):
func_private()
def test_private_and_beta(self, recwarn):
@_availability_warning(stability=Stability.BETA, visibility=Visibility.PRIVATE)
def func_private_and_beta(*args, **kwargs):
pass
with pytest.warns(
GeneralAvailabilityWarning,
match="This API is private.",
):
func_private_and_beta()
|