Exemplo n.º 1
0
    def test_lookup_future_by_expiration(self):
        metadata = {
            2: {
                'symbol': 'ADN15',
                'root_symbol': 'AD',
                'asset_type': 'future',
                'expiration_date': pd.Timestamp('2015-06-15', tz='UTC'),
                'start_date': pd.Timestamp('2015-01-01', tz='UTC')
            },
            1: {
                'symbol': 'ADV15',
                'root_symbol': 'AD',
                'asset_type': 'future',
                'expiration_date': pd.Timestamp('2015-09-14', tz='UTC'),
                'start_date': pd.Timestamp('2015-01-01', tz='UTC')
            },
            0: {
                'symbol': 'ADF16',
                'root_symbol': 'AD',
                'asset_type': 'future',
                'expiration_date': pd.Timestamp('2015-12-14', tz='UTC'),
                'start_date': pd.Timestamp('2015-01-01', tz='UTC')
            },

        }

        finder = AssetFinder(metadata=metadata)
        dt = pd.Timestamp('2015-06-19', tz='UTC')

        # First-of-the-month timestamps
        may_15 = pd.Timestamp('2015-05-01', tz='UTC')
        june_15 = pd.Timestamp('2015-06-01', tz='UTC')
        sept_15 = pd.Timestamp('2015-09-01', tz='UTC')
        dec_15 = pd.Timestamp('2015-12-01', tz='UTC')
        jan_16 = pd.Timestamp('2016-01-01', tz='UTC')

        # ADV15 is the next valid contract, so check that we get it
        # for every ref_date before 9/14/15
        contract = finder.lookup_future_by_expiration('AD', dt, may_15)
        self.assertEqual(contract.sid, 1)

        contract = finder.lookup_future_by_expiration('AD', dt, june_15)
        self.assertEqual(contract.sid, 1)

        contract = finder.lookup_future_by_expiration('AD', dt, sept_15)
        self.assertEqual(contract.sid, 1)

        # ADF16 has the next expiration date after 12/1/15
        contract = finder.lookup_future_by_expiration('AD', dt, dec_15)
        self.assertEqual(contract.sid, 0)

        # No contracts exist after 12/14/2015, so we should get none
        self.assertIsNone(finder.lookup_future_by_expiration('AD', dt, jan_16))
Exemplo n.º 2
0
    def test_lookup_future_by_expiration(self):
        metadata = {
            2: {
                'symbol': 'ADN15',
                'root_symbol': 'AD',
                'asset_type': 'future',
                'expiration_date': pd.Timestamp('2015-06-15', tz='UTC')
            },
            1: {
                'symbol': 'ADV15',
                'root_symbol': 'AD',
                'asset_type': 'future',
                'expiration_date': pd.Timestamp('2015-09-14', tz='UTC')
            },
            0: {
                'symbol': 'ADF16',
                'root_symbol': 'AD',
                'asset_type': 'future',
                'expiration_date': pd.Timestamp('2015-12-14', tz='UTC')
            },

        }

        finder = AssetFinder(metadata=metadata)
        dt = pd.Timestamp('2015-06-19', tz='UTC')

        # First-of-the-month timestamps
        may_15 = pd.Timestamp('2015-05-01', tz='UTC')
        june_15 = pd.Timestamp('2015-06-01', tz='UTC')
        sept_15 = pd.Timestamp('2015-09-01', tz='UTC')
        dec_15 = pd.Timestamp('2015-12-01', tz='UTC')
        jan_16 = pd.Timestamp('2016-01-01', tz='UTC')

        # ADV15 is the next valid contract, so check that we get it
        # for every ref_date before 9/14/15
        contract = finder.lookup_future_by_expiration('AD', dt, may_15)
        self.assertEqual(contract.sid, 1)

        contract = finder.lookup_future_by_expiration('AD', dt, june_15)
        self.assertEqual(contract.sid, 1)

        contract = finder.lookup_future_by_expiration('AD', dt, sept_15)
        self.assertEqual(contract.sid, 1)

        # ADF16 has the next expiration date after 12/1/15
        contract = finder.lookup_future_by_expiration('AD', dt, dec_15)
        self.assertEqual(contract.sid, 0)

        # No contracts exist after 12/14/2015, so we should get none
        self.assertIsNone(finder.lookup_future_by_expiration('AD', dt, jan_16))