Evernote API(Python SDK)は、sandboxでレートリミットを実装する予定ですが、レート制限は15秒間しかありません。Evernote APIサンドボックスレート制限期間15秒以上
例外が発生するまで、API呼び出しを作成してレート制限をテストするテストスイートがあります。
1分待ってから同じエラーEDAMSystemException(errorCode=19, rateLimitDuration=2651, _message='DuplicateNoteLimiter')
が発生します。
コード:errorCode=RATE_LIMIT_REACHED
に加え
from evernote.api.client import EvernoteClient
from evernote.edam.error.ttypes import EDAMSystemException
import evernote.edam.type.ttypes as Types
import time
def getClient():
return EvernoteClient(
token=config.dev_token,
sandbox=True
)
def makeNote(client):
note = Types.Note()
note.title = 'spam'
content = ''
note.content = '<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE en-note SYSTEM "http://xml.evernote.com/pub/enml2.dtd">'
note.content += '<en-note>'+ content + '</en-note>'
return client.get_note_store().createNote(note)
def test_api_limit():
client = getClient()
try:
while(True):
makeNote(client)
except EDAMSystemException as e:
assert e.errorCode == 19
print 'Caught Rate Limit Exception'
time.sleep(60)
makeNote(client) # still raise exception
print 'No exception occurred!' # this statement is not executed.
test_api_limit()