Skip to content

Commit

Permalink
Eliminate Windows Vista and Windows 7 conditionals
Browse files Browse the repository at this point in the history
  • Loading branch information
kurtmckee committed Sep 27, 2024
1 parent 152e6da commit 813b8a4
Show file tree
Hide file tree
Showing 4 changed files with 48 additions and 95 deletions.
7 changes: 1 addition & 6 deletions src/smartcard/Examples/scard-api/sample_listInterfaces.py
Original file line number Diff line number Diff line change
Expand Up @@ -54,12 +54,7 @@ def main():
try:

# list interfaces for a known card
if -1 != platform.platform().find('Windows-7'):
expectedCard = 'Identity Device (Microsoft Generic Profile)'
elif -1 != platform.platform().find('Windows-Vista-6.0'):
expectedCard = 'Axalto Cryptoflex .NET'
else:
expectedCard = 'Schlumberger Cryptoflex 8k v2'
expectedCard = 'Schlumberger Cryptoflex 8k v2'
hresult, interfaces = SCardListInterfaces(
hcontext,
expectedCard)
Expand Down
3 changes: 1 addition & 2 deletions src/smartcard/test/framework/testcase_readergroups.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,7 @@
from smartcard.scard import resourceManager


if 'winscard' == resourceManager and \
-1 == platform.platform().find('Windows-7'):
if 'winscard' == resourceManager:

class testcase_readergroups(unittest.TestCase):
"""Test smartcard framework readersgroups."""
Expand Down
98 changes: 29 additions & 69 deletions src/smartcard/test/scard/testcase_listcards.py
Original file line number Diff line number Diff line change
Expand Up @@ -85,28 +85,13 @@ def __forgetinterface(self):
# locate a known card
# Cryptoflex 8k v2 is present in standard Windows 2000
def test_listcryptoflexbyatr(self):
if -1 != platform.platform().find('Windows-7'):
dmyATR = \
[0x3B, 0x75, 0x94, 0x00, 0x00, 0x62, 0x02, 0x02, 0x01, 0x01]
dmyName = ['dummycard']
hresult, card = SCardListCards(self.hcontext, dmyATR, [])
self.assertEqual(hresult, 0)
self.assertEqual(card, dmyName)
elif -1 != platform.platform().find('Windows-Vista-6.0'):
axaltodotnetATR = \
[ 0x3B, 0x16, 0x96, 0x41, 0x73, 0x74, 0x72, 0x69, 0x64 ]
axaltodotnetName = ['Axalto Cryptoflex .NET']
hresult, card = SCardListCards(self.hcontext, axaltodotnetATR, [])
self.assertEqual(hresult, 0)
self.assertEqual(card, axaltodotnetName)
else:
slbCryptoFlex8kv2ATR = \
[0x3B, 0x95, 0x15, 0x40, 0x00, 0x68, 0x01, 0x02, 0x00, 0x00]
slbCryptoFlex8kv2Name = ['Schlumberger Cryptoflex 8K v2']
hresult, card = SCardListCards(
self.hcontext, slbCryptoFlex8kv2ATR, [])
self.assertEqual(hresult, 0)
self.assertEqual(card, slbCryptoFlex8kv2Name)
slbCryptoFlex8kv2ATR = \
[0x3B, 0x95, 0x15, 0x40, 0x00, 0x68, 0x01, 0x02, 0x00, 0x00]
slbCryptoFlex8kv2Name = ['Schlumberger Cryptoflex 8K v2']
hresult, card = SCardListCards(
self.hcontext, slbCryptoFlex8kv2ATR, [])
self.assertEqual(hresult, 0)
self.assertEqual(card, slbCryptoFlex8kv2Name)

# locate dummy card by interface
def test_listdummycardbyguid(self):
Expand All @@ -129,22 +114,13 @@ def test_listdummycardinterfaces(self):
# locate all cards and interfaces in the system
def test_listallcards(self):

if -1 != platform.platform().find('Windows-7'):
expectedCards = ['Identity Device (Microsoft Generic Profile)',
'Identity Device (NIST SP 800-73 [PIV])']
elif -1 != platform.platform().find('Windows-Vista-6.0'):
expectedCards = [
'Axalto Cryptoflex .NET',
'Infineon SICRYPT CardModule Card',
'dummycard' ]
else:
# dummycard has been introduced in the test setup and
# will be removed in the test teardown. Other cards are
# the cards present by default on Windows 2000
expectedCards = ['dummycard', 'GemSAFE Smart Card (8K)',
'Schlumberger Cryptoflex 4K',
'Schlumberger Cryptoflex 8K',
'Schlumberger Cryptoflex 8K v2']
# dummycard has been introduced in the test setup and
# will be removed in the test teardown. Other cards are
# the cards present by default on Windows 2000
expectedCards = ['dummycard', 'GemSAFE Smart Card (8K)',
'Schlumberger Cryptoflex 4K',
'Schlumberger Cryptoflex 8K',
'Schlumberger Cryptoflex 8K v2']
hresult, cards = SCardListCards(self.hcontext, [], [])
self.assertEqual(hresult, 0)
foundCards = {}
Expand All @@ -155,20 +131,12 @@ def test_listallcards(self):

# dummycard has a primary provider,
# other cards have no primary provider
if 'Windows-7-6.1.7600' == platform.platform():
expectedPrimaryProviderResult = {
'dummycard': [0, self.dummycardguid1],
'Identity Device (Microsoft Generic Profile)': \
[2, None],
'Identity Device (NIST SP 800-73 [PIV])': \
[2, None]}
else:
expectedPrimaryProviderResult = {
'dummycard': [0, self.dummycardguid1],
'GemSAFE': [2, None],
'Schlumberger Cryptoflex 4k': [2, None],
'Schlumberger Cryptoflex 8k': [2, None],
'Schlumberger Cryptoflex 8k v2': [2, None]}
expectedPrimaryProviderResult = {
'dummycard': [0, self.dummycardguid1],
'GemSAFE': [2, None],
'Schlumberger Cryptoflex 4k': [2, None],
'Schlumberger Cryptoflex 8k': [2, None],
'Schlumberger Cryptoflex 8k v2': [2, None]}
for i in range(len(cards)):
hresult, providername = SCardGetCardTypeProviderName(
self.hcontext, cards[i], SCARD_PROVIDER_PRIMARY)
Expand All @@ -183,23 +151,15 @@ def test_listallcards(self):
expectedPrimaryProviderResult[cards[i]][1]))

# dummycard has no CSP, other cards have a CSP
if 'Windows-7-6.1.7600' == platform.platform():
expectedProviderCSPResult = {
'dummycard': [2, None],
'Identity Device (Microsoft Generic Profile)': \
[0, 'Microsoft Base Smart Card Crypto Provider'],
'Identity Device (NIST SP 800-73 [PIV])': \
[0, 'Microsoft Base Smart Card Crypto Provider']}
else:
expectedProviderCSPResult = {
'dummycard': [2, None],
'GemSAFE': [0, 'Gemplus GemSAFE Card CSP v1.0'],
'Schlumberger Cryptoflex 4k': \
[0, 'Schlumberger Cryptographic Service Provider'],
'Schlumberger Cryptoflex 8k': \
[0, 'Schlumberger Cryptographic Service Provider'],
'Schlumberger Cryptoflex 8k v2': \
[0, 'Schlumberger Cryptographic Service Provider']}
expectedProviderCSPResult = {
'dummycard': [2, None],
'GemSAFE': [0, 'Gemplus GemSAFE Card CSP v1.0'],
'Schlumberger Cryptoflex 4k': \
[0, 'Schlumberger Cryptographic Service Provider'],
'Schlumberger Cryptoflex 8k': \
[0, 'Schlumberger Cryptographic Service Provider'],
'Schlumberger Cryptoflex 8k v2': \
[0, 'Schlumberger Cryptographic Service Provider']}
for i in range(len(cards)):
hresult, providername = SCardGetCardTypeProviderName(
self.hcontext, cards[i], SCARD_PROVIDER_CSP)
Expand Down
35 changes: 17 additions & 18 deletions src/smartcard/test/scard/testcase_locatecards.py
Original file line number Diff line number Diff line change
Expand Up @@ -77,24 +77,23 @@ def test_locateCards(self):
self.hcontext, cards, readerstates)
self.assertEqual(hresult, 0)

if -1 == platform.platform().find('Windows-7'):
dictexpectedreaders = {}
for reader in expectedReaders:
dictexpectedreaders[reader] = 1
for reader, eventstate, atr in newstates:
if reader in dictexpectedreaders and \
[] != expectedATRinReader[reader]:
self.assertEqual(expectedATRinReader[reader], atr)
self.assertTrue(eventstate & SCARD_STATE_PRESENT)
self.assertTrue(eventstate & SCARD_STATE_CHANGED)

# 10ms delay, so that time-out always occurs
hresult, newstates = SCardGetStatusChange(
self.hcontext, 10, newstates)
self.assertEqual(hresult, SCARD_E_TIMEOUT)
self.assertEqual(
SCardGetErrorMessage(hresult),
'The user-specified timeout value has expired. ')
dictexpectedreaders = {}
for reader in expectedReaders:
dictexpectedreaders[reader] = 1
for reader, eventstate, atr in newstates:
if reader in dictexpectedreaders and \
[] != expectedATRinReader[reader]:
self.assertEqual(expectedATRinReader[reader], atr)
self.assertTrue(eventstate & SCARD_STATE_PRESENT)
self.assertTrue(eventstate & SCARD_STATE_CHANGED)

# 10ms delay, so that time-out always occurs
hresult, newstates = SCardGetStatusChange(
self.hcontext, 10, newstates)
self.assertEqual(hresult, SCARD_E_TIMEOUT)
self.assertEqual(
SCardGetErrorMessage(hresult),
'The user-specified timeout value has expired. ')

elif 'pcsclite' == resourceManager:
readerstates = []
Expand Down

0 comments on commit 813b8a4

Please sign in to comment.