Skip to content

Commit

Permalink
WattTime#130 Split test_ercot.py into unit test and integration tests.
Browse files Browse the repository at this point in the history
This commit splits test_ercot.py into unit tests, which have no external
dependencies, and integration tests, which test pyiso's integration
with external systems (e.g. ERCOT's web servers).
  • Loading branch information
r24mille committed Sep 4, 2017
1 parent 652fd27 commit 19aef1a
Show file tree
Hide file tree
Showing 4 changed files with 200 additions and 187 deletions.
88 changes: 88 additions & 0 deletions tests/fixtures/ercot/real_time_system_conditions.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
<html>
<head>
<script>
setTimeout("window.location.reload(true);",60000);
</script>
<title>Real-Time System Conditions</title>
<meta http-equiv='pragma' content='no-cache'>
<link rel="stylesheet" type="text/css" href="/content/styles/cdr_reports.css" />
<script>
function open_window(url) {
window.open(url,"help",'toolbar=0,location=0,directories=0,status=0,menubar=0,scrollbars=yes,resizable=0,width=750,height=825');
};
</script>
<!-- Google Analytics -->
<script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','//www.google-analytics.com/analytics.js','ga');

ga('create', 'UA-460876-10', 'auto');
ga('send', 'pageview');
</script>
<!-- End Google Analytics -->
</head>
<body class="bodyStyle">
<div style="display: inline-block;">
<div>
<div class='header1'>Real-Time System Conditions</div>
<div class='helpLink'><a href="javascript:open_window('/help/popup/rtSysCondHelp')">Help?</a></div>
</div>
<br>
<div class="schedTime rightAlign">Last Updated: Apr 14, 2016 18:38:40</div>
<table class="tableStyle">
<tbody>
<tr>
<td class="headerValueClass" colSpan="2">Frequency</td>
</tr>
<td class="tdLeft">Current Frequency</td>
<td class="labelClassCenter">59.998</td>
</tr>
</tr>
<td class="tdLeft">Instantaneous Time Error</td>
<td class="labelClassCenter">-17.468</td>
</tr>
<tr>
<td class="headerValueClass" colSpan="2">Real-Time Data</td>
</tr>
</tr>
<td class="tdLeft">Actual System Demand</td>
<td class="labelClassCenter">38850</td>
</tr>
</tr>
<td class="tdLeft">Total System Capacity (not including Ancillary Services)</td>
<td class="labelClassCenter">42514</td>
</tr>
</tr>
<td class="tdLeft">Total Wind Output</td>
<td class="labelClassCenter">5242</td>
</tr>
<tr>
<td class="headerValueClass" colSpan="2">DC Tie Flows</td>
</tr>
</tr>
<td class="tdLeft">DC_E (East)</td>
<td class="labelClassCenter">-31</td>
</tr>
</tr>
<td class="tdLeft">DC_L (Laredo VFT)</td>
<td class="labelClassCenter">0</td>
</tr>
</tr>
<td class="tdLeft">DC_N (North)</td>
<td class="labelClassCenter">0</td>
</tr>
</tr>
<td class="tdLeft">DC_R (Railroad)</td>
<td class="labelClassCenter">0</td>
</tr>
</tr>
<td class="tdLeft">DC_S (Eagle Pass)</td>
<td class="labelClassCenter">1</td>
</tr>
</tbody>
</table>
</div>
</body>
</html>
61 changes: 61 additions & 0 deletions tests/integration/integration_test_ercot.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
from pyiso import client_factory
from unittest import TestCase
import pytz
from datetime import datetime, timedelta
import pandas as pd


class IntegrationTestERCOT(TestCase):
def setUp(self):
self.c = client_factory('ERCOT')

def test_request_report_gen_hrly(self):
# get data as list of dicts
df = self.c._request_report('gen_hrly')

# test for expected data
self.assertEqual(len(df), 1)
for key in ['SE_EXE_TIME_DST', 'SE_EXE_TIME', 'SE_MW']:
self.assertIn(key, df.columns)

def test_request_report_wind_hrly(self):
# get data as list of dicts
df = self.c._request_report('wind_hrly')

# test for expected data
self.assertLessEqual(len(df), 96)
for key in ['DSTFlag', 'ACTUAL_SYSTEM_WIDE', 'HOUR_ENDING']:
self.assertIn(key, df.columns)

def test_request_report_load_7day(self):
# get data as list of dicts
df = self.c._request_report('load_7day')

# test for expected data
# subtract 1 hour for DST
self.assertGreaterEqual(len(df), 8 * 24 - 1)
for key in ['SystemTotal', 'HourEnding', 'DSTFlag', 'DeliveryDate']:
self.assertIn(key, df.columns)

def test_request_report_dam_hrl_lmp(self):
now = datetime.now(pytz.timezone(self.c.TZ_NAME))
df = self.c._request_report('dam_hrly_lmp', now)
s = pd.to_datetime(df['DeliveryDate'], utc=True)

self.assertEqual(s.min().date(), now.date())
self.assertEqual(s.max().date(), now.date())

node_counts = range(612, 630)
self.assertIn(len(df), [n * 24 for n in node_counts]) # nodes * 24 hrs/day

def test_request_report_rt5m_lmp(self):
now = datetime.now(pytz.utc) - timedelta(minutes=5)
df = self.c._request_report('rt5m_lmp', now)
df.index = df['SCEDTimestamp']
s = pd.to_datetime(df.index).tz_localize('Etc/GMT+5').tz_convert('utc')

self.assertLess((s.min() - now).total_seconds(), 8 * 60)
self.assertLess((s.max() - now).total_seconds(), 8 * 60)

node_counts = range(612, 630)
self.assertIn(len(df), node_counts)
187 changes: 0 additions & 187 deletions tests/test_ercot.py

This file was deleted.

51 changes: 51 additions & 0 deletions tests/unit/test_ercot.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
import os

from pyiso import client_factory
from unittest import TestCase
import pytz
from datetime import datetime


FIXTURES_DIR = os.path.join(os.path.dirname(__file__), '../fixtures/ercot')


class TestERCOT(TestCase):

def setUp(self):
self.c = client_factory('ERCOT')
self.rtm_html = open(FIXTURES_DIR + '/real_time_system_conditions.html').read().encode('utf8')

def test_utcify(self):
ts_str = '05/03/2014 02:00'
ts = self.c.utcify(ts_str)
self.assertEqual(ts.year, 2014)
self.assertEqual(ts.month, 5)
self.assertEqual(ts.day, 3)
self.assertEqual(ts.hour, 2+5)
self.assertEqual(ts.minute, 0)
self.assertEqual(ts.tzinfo, pytz.utc)

def test_parse_load(self):
self.c.handle_options(data='load', latest=True)
data = self.c.parse_rtm(self.rtm_html)
self.assertEqual(len(data), 1)
expected_keys = ['timestamp', 'ba_name', 'load_MW', 'freq', 'market']
self.assertEqual(sorted(data[0].keys()), sorted(expected_keys))
self.assertEqual(data[0]['timestamp'], pytz.utc.localize(datetime(2016, 4, 14, 23, 38, 40)))
self.assertEqual(data[0]['load_MW'], 38850.0)

def test_parse_genmix(self):
self.c.handle_options(data='gen', latest=True)
data = self.c.parse_rtm(self.rtm_html)

self.assertEqual(len(data), 2)
expected_keys = ['timestamp', 'ba_name', 'gen_MW', 'fuel_name', 'freq', 'market']
self.assertEqual(sorted(data[0].keys()), sorted(expected_keys))

self.assertEqual(data[0]['timestamp'], pytz.utc.localize(datetime(2016, 4, 14, 23, 38, 40)))
self.assertEqual(data[0]['gen_MW'], 5242.0)
self.assertEqual(data[0]['fuel_name'], 'wind')

self.assertEqual(data[1]['timestamp'], pytz.utc.localize(datetime(2016, 4, 14, 23, 38, 40)))
self.assertEqual(data[1]['gen_MW'], 38850 - 5242 + 31 - 1)
self.assertEqual(data[1]['fuel_name'], 'nonwind')

0 comments on commit 19aef1a

Please sign in to comment.