Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

typing(search): Add parent class for ErrorsQueryBuilder #78213

Closed
wants to merge 1 commit into from

Conversation

armenzg
Copy link
Member

@armenzg armenzg commented Sep 26, 2024

Fixes these issues:

mypy src/sentry/search/events/builder/errors.py
src/sentry/search/events/builder/errors.py:40: error: "parse_query" undefined in superclass  [misc]
src/sentry/search/events/builder/errors.py:43: error: "ErrorsQueryBuilderMixin" has no attribute "params"  [attr-defined]
src/sentry/search/events/builder/errors.py:44: error: "ErrorsQueryBuilderMixin" has no attribute "params"  [attr-defined]
src/sentry/search/events/builder/errors.py:45: error: "ErrorsQueryBuilderMixin" has no attribute "params"  [attr-defined]
src/sentry/search/events/builder/errors.py:52: error: "ErrorsQueryBuilderMixin" has no attribute "dataset"  [attr-defined]
src/sentry/search/events/builder/errors.py:52: error: "ErrorsQueryBuilderMixin" has no attribute "sample_rate"  [attr-defined]
src/sentry/search/events/builder/errors.py:62: error: "resolve_params" undefined in superclass  [misc]
src/sentry/search/events/builder/errors.py:68: error: "ErrorsQueryBuilderMixin" has no attribute "params"  [attr-defined]
src/sentry/search/events/builder/errors.py:81: error: "resolve_query" undefined in superclass  [misc]
src/sentry/search/events/builder/errors.py:85: error: "aliased_column" undefined in superclass  [misc]
src/sentry/search/events/builder/errors.py:100: error: "ErrorsQueryBuilderMixin" has no attribute "resolve_column_name"  [attr-defined]
src/sentry/search/events/builder/errors.py:108: error: "ErrorsQueryBuilderMixin" has no attribute "dataset"  [attr-defined]
Found 12 errors in 1 file (checked 1 source file)

@armenzg armenzg self-assigned this Sep 26, 2024
@github-actions github-actions bot added the Scope: Backend Automatically applied to PRs that change backend components label Sep 26, 2024
@@ -30,7 +31,7 @@
value_converters = {"status": convert_status_value}


class ErrorsQueryBuilderMixin:
class ErrorsQueryBuilderMixin(BaseQueryBuilder):
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The missing parameters are set here:

def __init__(
self,
dataset: Dataset,
params: ParamsType,
config: QueryBuilderConfig | None = None,
snuba_params: SnubaParams | None = None,
query: str | None = None,
selected_columns: list[str] | None = None,
groupby_columns: list[str] | None = None,
equations: list[str] | None = None,
orderby: list[str] | str | None = None,
limit: int | None = 50,
offset: int | None = 0,
limitby: tuple[str, int] | None = None,
turbo: bool = False,
sample_rate: float | None = None,
array_join: str | None = None,
entity: Entity | None = None,
):
if config is None:
self.builder_config = QueryBuilderConfig()
else:
self.builder_config = config
if self.builder_config.parser_config_overrides is None:
self.builder_config.parser_config_overrides = {}
self.dataset = dataset
# filter params is the older style params, shouldn't be used anymore
self.filter_params = params
if snuba_params is not None:
self.filter_params = snuba_params.filter_params
self.params = self._dataclass_params(snuba_params, params)
org_id = self.params.organization_id
self.organization_id: int | None = (
org_id if org_id is not None and isinstance(org_id, int) else None
)
self.raw_equations = equations
self.raw_orderby = orderby
self.query = query
self.selected_columns = selected_columns
self.groupby_columns = groupby_columns
self.tips: dict[str, set[str]] = {
"query": set(),
"columns": set(),
}
# Base Tenant IDs for any Snuba Request built/executed using a QueryBuilder
org_id = self.organization_id or (
self.params.organization.id if self.params.organization else None
)
self.tenant_ids: dict[str, str | None | int] | None = dict()
if org_id is not None:
self.tenant_ids["organization_id"] = org_id
if "use_case_id" in params and params.get("use_case_id") is not None:
self.tenant_ids["use_case_id"] = params.get("use_case_id")
if not self.tenant_ids:
self.tenant_ids = None
# Function is a subclass of CurriedFunction
self.where: list[WhereType] = []
self.having: list[WhereType] = []
# The list of aggregates to be selected
self.aggregates: list[CurriedFunction] = []
self.columns: list[SelectType] = []
self.orderby: list[OrderBy] = []
self.groupby: list[SelectType] = []
self.projects_to_filter: set[int] = set()
self.function_alias_map: dict[str, fields.FunctionDetails] = {}
self.equation_alias_map: dict[str, SelectType] = {}
# field: function map for post-processing values
self.value_resolver_map: dict[str, Callable[[Any], Any]] = {}
# value_resolver_map may change type
self.meta_resolver_map: dict[str, str] = {}
# These maps let us convert from prefixed to original tag keys
# and vice versa to avoid collisions where tags and functions have
# similar aliases
self.prefixed_to_tag_map: dict[str, str] = {}
self.tag_to_prefixed_map: dict[str, str] = {}
# Tags with their type in them can't be passed to clickhouse because of the space
# This map is so we can convert those back before the user sees the internal alias
self.typed_tag_to_alias_map: dict[str, str] = {}
self.alias_to_typed_tag_map: dict[str, str] = {}
self.requires_other_aggregates = False
self.limit = self.resolve_limit(limit)
self.offset = None if offset is None else Offset(offset)
self.turbo = turbo
self.sample_rate = sample_rate
self.config = self.load_config()
self.parse_config()
self.start: datetime | None = None
self.end: datetime | None = None
self.resolve_query(
query=query,
selected_columns=selected_columns,
groupby_columns=groupby_columns,
equations=equations,
orderby=orderby,
)
self.entity = entity
self.limitby = self.resolve_limitby(limitby)
self.array_join = None if array_join is None else [self.resolve_column(array_join)]

mypy src/sentry/search/events/builder/errors.py
src/sentry/search/events/builder/errors.py:40: error: "parse_query" undefined in superclass  [misc]
src/sentry/search/events/builder/errors.py:43: error: "ErrorsQueryBuilderMixin" has no attribute "params"  [attr-defined]
src/sentry/search/events/builder/errors.py:44: error: "ErrorsQueryBuilderMixin" has no attribute "params"  [attr-defined]
src/sentry/search/events/builder/errors.py:45: error: "ErrorsQueryBuilderMixin" has no attribute "params"  [attr-defined]
src/sentry/search/events/builder/errors.py:52: error: "ErrorsQueryBuilderMixin" has no attribute "dataset"  [attr-defined]
src/sentry/search/events/builder/errors.py:52: error: "ErrorsQueryBuilderMixin" has no attribute "sample_rate"  [attr-defined]
src/sentry/search/events/builder/errors.py:62: error: "resolve_params" undefined in superclass  [misc]
src/sentry/search/events/builder/errors.py:68: error: "ErrorsQueryBuilderMixin" has no attribute "params"  [attr-defined]
src/sentry/search/events/builder/errors.py:81: error: "resolve_query" undefined in superclass  [misc]
src/sentry/search/events/builder/errors.py:85: error: "aliased_column" undefined in superclass  [misc]
src/sentry/search/events/builder/errors.py:100: error: "ErrorsQueryBuilderMixin" has no attribute "resolve_column_name"  [attr-defined]
src/sentry/search/events/builder/errors.py:108: error: "ErrorsQueryBuilderMixin" has no attribute "dataset"  [attr-defined]
Found 12 errors in 1 file (checked 1 source file)

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

mixins in general aren't typesafe -- this should probably be refactored to composition or otherwise

Copy link

codecov bot commented Sep 26, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

✅ All tests successful. No failed tests found.

Additional details and impacted files
@@            Coverage Diff             @@
##           master   #78213      +/-   ##
==========================================
+ Coverage   78.09%   78.10%   +0.01%     
==========================================
  Files        7036     7038       +2     
  Lines      311491   311519      +28     
  Branches    50913    50916       +3     
==========================================
+ Hits       243264   243322      +58     
+ Misses      56468    56447      -21     
+ Partials    11759    11750       -9     

@getsantry
Copy link
Contributor

getsantry bot commented Oct 18, 2024

This pull request has gone three weeks without activity. In another week, I will close it.

But! If you comment or otherwise update it, I will reset the clock, and if you add the label WIP, I will leave it alone unless WIP is removed ... forever!


"A weed is but an unloved flower." ― Ella Wheeler Wilcox 🥀

@getsantry getsantry bot added Stale and removed Stale labels Oct 18, 2024
@armenzg armenzg removed the request for review from a team October 24, 2024 12:24
@getsantry
Copy link
Contributor

getsantry bot commented Nov 15, 2024

This pull request has gone three weeks without activity. In another week, I will close it.

But! If you comment or otherwise update it, I will reset the clock, and if you add the label WIP, I will leave it alone unless WIP is removed ... forever!


"A weed is but an unloved flower." ― Ella Wheeler Wilcox 🥀

@getsantry getsantry bot added Stale and removed Stale labels Nov 15, 2024
@getsantry
Copy link
Contributor

getsantry bot commented Dec 8, 2024

This pull request has gone three weeks without activity. In another week, I will close it.

But! If you comment or otherwise update it, I will reset the clock, and if you add the label WIP, I will leave it alone unless WIP is removed ... forever!


"A weed is but an unloved flower." ― Ella Wheeler Wilcox 🥀

@getsantry getsantry bot added Stale and removed Stale labels Dec 8, 2024
@getsantry
Copy link
Contributor

getsantry bot commented Dec 31, 2024

This pull request has gone three weeks without activity. In another week, I will close it.

But! If you comment or otherwise update it, I will reset the clock, and if you add the label WIP, I will leave it alone unless WIP is removed ... forever!


"A weed is but an unloved flower." ― Ella Wheeler Wilcox 🥀

@getsantry getsantry bot added the Stale label Dec 31, 2024
@getsantry getsantry bot closed this Jan 8, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Scope: Backend Automatically applied to PRs that change backend components Stale
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants