-
Notifications
You must be signed in to change notification settings - Fork 16
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
Feature/add conversions #36
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@fivetran-jamie these changes look great! I just have a few minor suggestions, but none related to the actual code. I see this being a huge value add for our users!
Once you address the comments in this review let's hold off merging until the other updates in the Google and LinkedIn packages are ready as well. Thanks and great job!
{# | ||
Adapted from fivetran_utils.fill_pass_through_columns() macro. | ||
Ensures that downstream summations work if a connector schema is missing one of your facebook_ads__basic_ad_actions_passthrough_metrics | ||
#} | ||
{% if var('facebook_ads__basic_ad_actions_passthrough_metrics') %} | ||
{% for field in var('facebook_ads__basic_ad_actions_passthrough_metrics') %} | ||
{% if field.transform_sql %} | ||
, coalesce(cast({{ field.transform_sql }} as {{ dbt.type_float() }}), 0) as {{ field.alias if field.alias else field.name }} | ||
{% else %} | ||
, coalesce(cast({{ field.alias if field.alias else field.name }} as {{ dbt.type_float() }}), 0) as {{ field.alias if field.alias else field.name }} | ||
{% endif %} | ||
{% endfor %} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we consider making this a macro?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
going back and forth on this one, as the code is more complex than what's usually in our staging models, but it is really only used in this one model, so creating a macro wouldn't make us any DRYer. what are your thoughts?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That's a good point. If it won't make things much dryer then there is no point in wrapping it up in a macro. I am good leaving as is. Thanks!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this is now in 2 models, should i macro-fy? @fivetran-joemarkiewicz
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@fivetran-jamie yeah since we need to maintain it in two separate places it makes sense to macro-fy. Thanks!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@fivetran-jamie can we macro-fy this or is it not entirely necessary?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
added!
Co-authored-by: Joe Markiewicz <[email protected]>
We just ran into an issue where we wanted to create a solution for exactly this. This will be super helpful. |
FYI for anyone subscribed here, this is currently blocked. We are working with Engineering to ensure that the conversion monetary values ( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks @fivetran-jamie! This is looking really good. I have just a few comments and suggestions here as well as in the transform PR before this will be ready for final approval.
Co-authored-by: Joe Markiewicz <[email protected]>
Co-authored-by: Joe Markiewicz <[email protected]>
Co-authored-by: Joe Markiewicz <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM just one comment bumping the macro-fy the code in the staging models.
{# | ||
Adapted from fivetran_utils.fill_pass_through_columns() macro. | ||
Ensures that downstream summations work if a connector schema is missing one of your facebook_ads__basic_ad_actions_passthrough_metrics | ||
#} | ||
{% if var('facebook_ads__basic_ad_actions_passthrough_metrics') %} | ||
{% for field in var('facebook_ads__basic_ad_actions_passthrough_metrics') %} | ||
{% if field.transform_sql %} | ||
, coalesce(cast({{ field.transform_sql }} as {{ dbt.type_float() }}), 0) as {{ field.alias if field.alias else field.name }} | ||
{% else %} | ||
, coalesce(cast({{ field.alias if field.alias else field.name }} as {{ dbt.type_float() }}), 0) as {{ field.alias if field.alias else field.name }} | ||
{% endif %} | ||
{% endfor %} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@fivetran-jamie can we macro-fy this or is it not entirely necessary?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
very minor documentation comments! approved!
Co-authored-by: Renee Li <[email protected]>
PR Overview
This PR will address the following Issue/Feature:
No issue created
This PR will result in the following new package version:
v0.8.0 -- looking at our UI,
basic_ad_actions
is a child ofbasic_ad
and is included by default with it, but juuuust in case someone doesn't have the new table, let's make it breaking, as it is a schema change.Please provide the finalized CHANGELOG entry which details the relevant changes included in this PR:
🚨 Breaking Changes 🚨
basic_ad_actions
pre-built report in order to grab conversion data.basic_ad_actions
is a child table of the already-requiredbasic_ad
report, broken down byaction_type
.stg_facebook_ads__basic_ad_actions
(and its_tmp
counterpart) staging model. Given that this is a schema change for the package, this a breaking change.Feature Updates
basic_ad_actions
source table, creates afacebook_ads__basic_ad_actions_passthrough_metrics
variable to pass through additional conversion value metrics to downstream models. By default, the package includes only the conversion value calculated using the default attribution window, but your report may include calculations using the other windows defined here. See README for details on how to use the new var.optimization_goal
field tostg_facebook_ads__ad_set_history
model. This is defined as the optimization goal this ad set is using, possible values of which are defined here.conversion_domain
field tostg_facebook_ads__ad_history
model. This is defined as the domain you've configured the ad to convert to.Documentation
facebook_ads__basic_ad_passthrough_metrics
variable. See README for details.PR Checklist
Basic Validation
Please acknowledge that you have successfully performed the following commands locally:
Before marking this PR as "ready for review" the following have been applied:
Detailed Validation
Please share any and all of your validation steps:
See Validation tests in transform PR