mirror of
https://github.com/apache/superset.git
synced 2026-05-07 17:04:58 +00:00
fix(sqllab/charts): casting from timestamp[us] to timestamp[ns] would result in out of bounds timestamp (#18873)
* fix casting from timestamp[us] to timestamp[ns] would result in out of bounds timestamp from sqllab and charts
* Add unittests
* Lint changes and parameter variable rename
* Fix linting
(cherry picked from commit 8b72354654)
This commit is contained in:
committed by
Michael S. Molina
parent
9ca53b8905
commit
8becd3e080
@@ -15,6 +15,11 @@
|
||||
# specific language governing permissions and limitations
|
||||
# under the License.
|
||||
# pylint: disable=unused-argument, import-outside-toplevel
|
||||
from datetime import datetime
|
||||
|
||||
import pytest
|
||||
from pandas import Timestamp
|
||||
|
||||
from superset.dataframe import df_to_records
|
||||
from superset.superset_typing import DbapiDescription
|
||||
|
||||
@@ -53,3 +58,50 @@ def test_js_max_int(app_context: None) -> None:
|
||||
{"a": 1, "b": "1239162456494753670", "c": "c1"},
|
||||
{"a": 2, "b": 100, "c": "c2"},
|
||||
]
|
||||
|
||||
|
||||
@pytest.mark.parametrize(
|
||||
"input_, expected",
|
||||
[
|
||||
pytest.param(
|
||||
[
|
||||
(datetime.strptime("1677-09-22 00:12:43", "%Y-%m-%d %H:%M:%S"), 1),
|
||||
(datetime.strptime("2262-04-11 23:47:17", "%Y-%m-%d %H:%M:%S"), 2),
|
||||
],
|
||||
[
|
||||
{
|
||||
"a": datetime.strptime("1677-09-22 00:12:43", "%Y-%m-%d %H:%M:%S"),
|
||||
"b": 1,
|
||||
},
|
||||
{
|
||||
"a": datetime.strptime("2262-04-11 23:47:17", "%Y-%m-%d %H:%M:%S"),
|
||||
"b": 2,
|
||||
},
|
||||
],
|
||||
id="timestamp conversion fail",
|
||||
),
|
||||
pytest.param(
|
||||
[
|
||||
(datetime.strptime("1677-09-22 00:12:44", "%Y-%m-%d %H:%M:%S"), 1),
|
||||
(datetime.strptime("2262-04-11 23:47:16", "%Y-%m-%d %H:%M:%S"), 2),
|
||||
],
|
||||
[
|
||||
{"a": Timestamp("1677-09-22 00:12:44"), "b": 1},
|
||||
{"a": Timestamp("2262-04-11 23:47:16"), "b": 2},
|
||||
],
|
||||
id="timestamp conversion success",
|
||||
),
|
||||
],
|
||||
)
|
||||
def test_max_pandas_timestamp(input_, expected) -> None:
|
||||
from superset.db_engine_specs import BaseEngineSpec
|
||||
from superset.result_set import SupersetResultSet
|
||||
|
||||
cursor_descr: DbapiDescription = [
|
||||
("a", "datetime", None, None, None, None, False),
|
||||
("b", "int", None, None, None, None, False),
|
||||
]
|
||||
results = SupersetResultSet(input_, cursor_descr, BaseEngineSpec)
|
||||
df = results.to_pandas_df()
|
||||
|
||||
assert df_to_records(df) == expected
|
||||
|
||||
Reference in New Issue
Block a user