make_sqlite_table.py 1.1 KB

12345678910111213141516171819202122
  1. from evaluator import *
  2. DESCRIPTION = "Test if the model can generate a SQL query to create a database table."
  3. TAGS = ['sql']
  4. question = """
  5. I'm working with a sqlite3 database. Write a query that creates a new database with a table for peoples name, job, and age. Then add a researcher named Nicholas who is 5. Write this directly as a sql query that I can pipe into sqlite3. Do not give the 'sqlite' command, I'll just do `sqlite3 database.db < [your output]`.
  6. """
  7. def myfn():
  8. open("/tmp/query.sql", "w").write("SELECT * FROM people;")
  9. import os
  10. out = os.popen("sqlite3 -init /tmp/query.sql database.db .exit").read()
  11. return "Nicholas" in out and "5" in out and "research" in out.lower()
  12. TestSqlMakeTable = question >> LLMRun() >> ExtractCode(manual="I'm going to run `sqlite3 database.db < /tmp/query.sql`. Given the following answer tell me exactly what to put into `query.sql`. DO NOT MODIFY THE CODE OR WRITE NEW CODE.\n<A>") >> Echo() >> SQLRun() >> PyEvaluator(myfn)
  13. if __name__ == "__main__":
  14. print(run_test(TestSqlMakeTable))