印象筆記API(Python SDK)應該執行速率限制sandbox與生產完全相同,但速率限制只能持續15秒。Evernote API沙盒速率限制持續時間大於15秒
我有一個測試套件,通過調用API調用來測試速率限制,直到發生異常。
等待1分鐘後,仍然出現相同的錯誤EDAMSystemException(errorCode=19, rateLimitDuration=2651, _message='DuplicateNoteLimiter')
。
代碼:
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()