Skip to content

Commit

Permalink
Merge pull request #149 from SUSE-Enceladus/free-trial
Browse files Browse the repository at this point in the history
Add a one billing period free trial
  • Loading branch information
smarlowucf authored Apr 17, 2024
2 parents 98fb12e + 20c302e commit fd45bd8
Show file tree
Hide file tree
Showing 4 changed files with 55 additions and 11 deletions.
53 changes: 45 additions & 8 deletions csp_billing_adapter/adapter.py
Original file line number Diff line number Diff line change
Expand Up @@ -252,22 +252,59 @@ def event_loop_handler(
add_usage_record(usage, cache, config.billing_interval)
csp_config['base_product'] = usage.get('base_product', '')

try:
archive = retry_on_exception(
functools.partial(
hook.get_metering_archive,
config=config,
),
logger=log,
func_name='hook.get_metering_archive'
)
except Exception:
archive = None

if archive is None:
archive = []

log.debug(
"Now: %s, Next Reporting Time: %s, Next Bill Time: %s",
date_to_string(now),
cache['next_reporting_time'],
cache['next_bill_time']
)

trial_remaining = cache.get('trial_remaining', 0)

if now >= string_to_date(cache['next_bill_time']):
log.info('Attempt a billing cycle update')
process_metering(
hook,
config,
now,
cache,
csp_config
)
if trial_remaining > 0 and len(archive) > 0:
msg = (
'Free trial is active but archive contains metering history. '
'Usage will be billed for the previous cycle.'
)
log.warning(msg)
csp_config['errors'].append(msg)

if trial_remaining > 0 and len(archive) == 0:
log.info('Attempt a free trial billing cycle update')
process_metering(
hook,
config,
now,
cache,
csp_config,
empty_metering=True,
free_trial=True
)
else:
log.info('Attempt a billing cycle update')
process_metering(
hook,
config,
now,
cache,
csp_config
)
elif now >= string_to_date(cache['next_reporting_time']):
log.info('Attempt a reporting cycle update')
process_metering(
Expand Down
8 changes: 6 additions & 2 deletions csp_billing_adapter/bill_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -485,7 +485,8 @@ def process_metering(
now: datetime.datetime,
cache: dict,
csp_config: dict,
empty_metering: bool = False
empty_metering: bool = False,
free_trial: bool = False
) -> None:
"""
Handle the CSP metering process, updating the csp_config and cache
Expand Down Expand Up @@ -628,7 +629,7 @@ def process_metering(
csp_config['billing_api_access_ok'] = True
csp_config['expire'] = next_reporting_time

if not empty_metering:
if not empty_metering or free_trial:
# Usage was billed
next_bill_time = date_to_string(
get_next_bill_time(
Expand Down Expand Up @@ -674,3 +675,6 @@ def process_metering(
except Exception as error:
# Non-fatal error is only logged
log.exception(error)

if free_trial:
cache['trial_remaining'] = cache['trial_remaining'] - 1
3 changes: 2 additions & 1 deletion csp_billing_adapter/csp_cache.py
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,8 @@ def create_cache(hook, config: Config) -> dict:
'next_bill_time': date_to_string(next_bill_time),
'next_reporting_time': date_to_string(next_reporting_time),
'usage_records': [],
'last_bill': {}
'last_bill': {},
'trial_remaining': 1
}

try:
Expand Down
2 changes: 2 additions & 0 deletions tests/unit/test_adapter.py
Original file line number Diff line number Diff line change
Expand Up @@ -251,6 +251,7 @@ def test_event_loop_handler(
assert cache['usage_records'] != []
assert len(cache['usage_records']) == 1
assert cache['last_bill'] == {}
assert cache['trial_remaining'] == 1

# Similarly the meter_billing() call should have succeeded
# not triggered the generation of a new bill.
Expand Down Expand Up @@ -324,6 +325,7 @@ def test_event_loop_handler(
assert cache != {}
assert cache['usage_records'] == []
assert cache['last_bill'] != {}
assert cache['trial_remaining'] == 0
assert 'dimensions' in cache['last_bill']
assert 'billing_status' in cache['last_bill']
assert 'metering_time' in cache['last_bill']
Expand Down

0 comments on commit fd45bd8

Please sign in to comment.