mirror of https://github.com/google/oss-fuzz.git
sqlalchemy-utils: initial integration (#7852)
* sqlalchemy-utils: initial integration create basic fuzzer * Add new fuzzer * Add new fuzzer * fuzz_db: slight refactoring imports * fuzz_type: slight refactoring imports and adding comment * project.yaml: add primary contact Ref: https://github.com/kvesteri/sqlalchemy-utils/issues/615#issuecomment-1159740608 Co-authored-by: DavidKorczynski <david@adalogics.com>
This commit is contained in:
parent
189d30dbe5
commit
f4bec8cd49
|
@ -0,0 +1,22 @@
|
||||||
|
# Copyright 2022 Google LLC
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
#
|
||||||
|
################################################################################
|
||||||
|
|
||||||
|
FROM gcr.io/oss-fuzz-base/base-builder-python
|
||||||
|
|
||||||
|
RUN git clone https://github.com/kvesteri/sqlalchemy-utils
|
||||||
|
|
||||||
|
WORKDIR $SRC/sqlalchemy-utils
|
||||||
|
COPY build.sh fuzz_*.py $SRC/
|
|
@ -0,0 +1,25 @@
|
||||||
|
#!/bin/bash -eu
|
||||||
|
# Copyright 2022 Google LLC.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
#
|
||||||
|
################################################################################
|
||||||
|
|
||||||
|
# Build and install project (using current CFLAGS, CXXFLAGS).
|
||||||
|
pip3 install --upgrade pip
|
||||||
|
pip3 install sqlalchemy arrow colour babel
|
||||||
|
pip3 install -e .
|
||||||
|
|
||||||
|
for fuzzer in $(find $SRC -name 'fuzz_*.py'); do
|
||||||
|
compile_python_fuzzer $fuzzer
|
||||||
|
done
|
|
@ -0,0 +1,71 @@
|
||||||
|
#!/usr/bin/python3
|
||||||
|
# Copyright 2022 Google LLC
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
import atheris
|
||||||
|
import sys
|
||||||
|
|
||||||
|
with atheris.instrument_imports():
|
||||||
|
import sqlalchemy
|
||||||
|
from sqlalchemy import (
|
||||||
|
create_engine,
|
||||||
|
insert,
|
||||||
|
Table,
|
||||||
|
Column,
|
||||||
|
Integer,
|
||||||
|
String,
|
||||||
|
MetaData
|
||||||
|
)
|
||||||
|
import sqlalchemy_utils as utils
|
||||||
|
from sqlalchemy.sql import text
|
||||||
|
from sqlalchemy.exc import SQLAlchemyError
|
||||||
|
|
||||||
|
@atheris.instrument_func
|
||||||
|
def TestInput(data):
|
||||||
|
if len(data) < 10:
|
||||||
|
pass
|
||||||
|
|
||||||
|
fdp = atheris.FuzzedDataProvider(data)
|
||||||
|
|
||||||
|
db_str = 'sqlite:///fuzz.db'
|
||||||
|
|
||||||
|
metadata = MetaData()
|
||||||
|
fuzz_table = Table('fuzz_table', metadata,
|
||||||
|
Column('id', Integer, primary_key=True),
|
||||||
|
Column('Col1', String))
|
||||||
|
|
||||||
|
engine = create_engine(db_str)
|
||||||
|
metadata.create_all(engine)
|
||||||
|
|
||||||
|
if not utils.database_exists(db_str):
|
||||||
|
utils.create_database(db_str)
|
||||||
|
assert utils.database_exists(db_str)
|
||||||
|
|
||||||
|
try:
|
||||||
|
with engine.connect() as conn:
|
||||||
|
conn.execute(text(fdp.ConsumeString(100)))
|
||||||
|
except (SQLAlchemyError, UnicodeEncodeError) as e:
|
||||||
|
pass
|
||||||
|
except ValueError as e:
|
||||||
|
if "the query contains a null character" not in str(e):
|
||||||
|
raise e
|
||||||
|
|
||||||
|
utils.drop_database(db_str)
|
||||||
|
assert not utils.database_exists(db_str)
|
||||||
|
def main():
|
||||||
|
atheris.Setup(sys.argv, TestInput, enable_python_coverage=True)
|
||||||
|
atheris.Fuzz()
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
|
@ -0,0 +1,68 @@
|
||||||
|
#!/usr/bin/python3
|
||||||
|
# Copyright 2022 Google LLC
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
import atheris
|
||||||
|
import sys
|
||||||
|
|
||||||
|
with atheris.instrument_imports():
|
||||||
|
import sqlalchemy
|
||||||
|
from sqlalchemy import Column, Integer, String, select, create_engine
|
||||||
|
from sqlalchemy.orm import declarative_base, Session
|
||||||
|
from sqlalchemy_utils import cast_if, escape_like
|
||||||
|
from sqlalchemy.exc import SQLAlchemyError
|
||||||
|
|
||||||
|
Base = declarative_base()
|
||||||
|
|
||||||
|
class FuzzTable(Base):
|
||||||
|
__tablename__ = "fuzz_table"
|
||||||
|
|
||||||
|
id = Column(Integer, primary_key=True)
|
||||||
|
name = Column(String)
|
||||||
|
|
||||||
|
@atheris.instrument_func
|
||||||
|
def TestInput(data):
|
||||||
|
if len(data) < 10:
|
||||||
|
pass
|
||||||
|
|
||||||
|
fdp = atheris.FuzzedDataProvider(data)
|
||||||
|
|
||||||
|
cast_if(FuzzTable.id, Integer)
|
||||||
|
cast_if(FuzzTable.name, Integer)
|
||||||
|
cast_if(FuzzTable.id, String)
|
||||||
|
cast_if(FuzzTable.name, String)
|
||||||
|
|
||||||
|
cast_if(fdp.ConsumeInt(10), Integer)
|
||||||
|
cast_if(fdp.ConsumeString(10), Integer)
|
||||||
|
cast_if(fdp.ConsumeInt(10), String)
|
||||||
|
cast_if(fdp.ConsumeString(10), String)
|
||||||
|
|
||||||
|
db_str = 'sqlite:///fuzz.db'
|
||||||
|
|
||||||
|
engine = create_engine(db_str)
|
||||||
|
Base.metadata.create_all(engine)
|
||||||
|
|
||||||
|
try:
|
||||||
|
with Session(engine) as session:
|
||||||
|
name_str = fdp.ConsumeString(20)
|
||||||
|
session.query(FuzzTable).filter(FuzzTable.name.ilike(escape_like(name_str))).all()
|
||||||
|
except SQLAlchemyError as e:
|
||||||
|
pass
|
||||||
|
|
||||||
|
def main():
|
||||||
|
atheris.Setup(sys.argv, TestInput, enable_python_coverage=True)
|
||||||
|
atheris.Fuzz()
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
|
@ -0,0 +1,116 @@
|
||||||
|
#!/usr/bin/python3
|
||||||
|
# Copyright 2022 Google LLC
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
import atheris
|
||||||
|
import sys
|
||||||
|
|
||||||
|
with atheris.instrument_imports():
|
||||||
|
from arrow import utcnow
|
||||||
|
from colour import Color
|
||||||
|
from uuid import uuid4
|
||||||
|
|
||||||
|
import sqlalchemy
|
||||||
|
from sqlalchemy.sql import text, select
|
||||||
|
from sqlalchemy.exc import SQLAlchemyError
|
||||||
|
from sqlalchemy import (
|
||||||
|
create_engine, Integer, String, MetaData,
|
||||||
|
Table, Column, Sequence
|
||||||
|
)
|
||||||
|
from sqlalchemy_utils import (
|
||||||
|
ArrowType, ChoiceType, ColorType, CountryType,
|
||||||
|
Country, EmailType, JSONType, IPAddressType,
|
||||||
|
ScalarListType, URLType, UUIDType, WeekDays,
|
||||||
|
WeekDaysType
|
||||||
|
)
|
||||||
|
|
||||||
|
# The following imports are needed to make the pyinstaller
|
||||||
|
# executable work.
|
||||||
|
from babel import Locale
|
||||||
|
import babel.dates
|
||||||
|
import babel.numbers
|
||||||
|
|
||||||
|
|
||||||
|
@atheris.instrument_func
|
||||||
|
def TestInput(data):
|
||||||
|
if len(data) < 10:
|
||||||
|
pass
|
||||||
|
|
||||||
|
fdp = atheris.FuzzedDataProvider(data)
|
||||||
|
|
||||||
|
metadata = MetaData()
|
||||||
|
fuzz_table = Table('fuzz_table', metadata,
|
||||||
|
Column('id', Integer, Sequence('id_seq'), primary_key=True),
|
||||||
|
Column('Col1', String),
|
||||||
|
Column('Col2', ArrowType),
|
||||||
|
Column('Col3', ChoiceType(
|
||||||
|
[(u'c1', u'Choice 1'),(u'c2', u'Choice 2')]
|
||||||
|
)),
|
||||||
|
Column('Col4', ColorType),
|
||||||
|
Column('Col5', CountryType),
|
||||||
|
Column('Col6', EmailType),
|
||||||
|
Column('Col7', JSONType),
|
||||||
|
Column('Col8', IPAddressType),
|
||||||
|
Column('Col9', ScalarListType(int)),
|
||||||
|
Column('Col10', URLType),
|
||||||
|
Column('Col11', UUIDType(binary=False)),
|
||||||
|
Column('Col12', WeekDaysType)
|
||||||
|
)
|
||||||
|
|
||||||
|
engine = create_engine('sqlite:///fuzz.db')
|
||||||
|
metadata.create_all(engine)
|
||||||
|
try:
|
||||||
|
with engine.connect() as conn:
|
||||||
|
conn.execute(text(fdp.ConsumeString(100)))
|
||||||
|
ins = fuzz_table.insert().values(
|
||||||
|
Col1=fdp.ConsumeString(100),
|
||||||
|
Col2=utcnow(),
|
||||||
|
Col3=u'c1' if fdp.ConsumeBool() else u'c2',
|
||||||
|
Col4=Color("#{:02x}{:02x}{:02x}".format(
|
||||||
|
fdp.ConsumeIntInRange(0,255),
|
||||||
|
fdp.ConsumeIntInRange(0,255),
|
||||||
|
fdp.ConsumeIntInRange(0,255)
|
||||||
|
)),
|
||||||
|
Col5=Country('US'),
|
||||||
|
Col6=fdp.ConsumeString(20),
|
||||||
|
Col7={
|
||||||
|
fdp.ConsumeString(2):fdp.ConsumeString(10),
|
||||||
|
fdp.ConsumeString(2):fdp.ConsumeString(10),
|
||||||
|
fdp.ConsumeString(2):fdp.ConsumeString(10)
|
||||||
|
},
|
||||||
|
Col8="%d.%d.%d.%d"%(
|
||||||
|
fdp.ConsumeIntInRange(0,255),
|
||||||
|
fdp.ConsumeIntInRange(0,255),
|
||||||
|
fdp.ConsumeIntInRange(0,255),
|
||||||
|
fdp.ConsumeIntInRange(0,255)
|
||||||
|
),
|
||||||
|
Col9=[fdp.ConsumeInt(8),fdp.ConsumeInt(8),fdp.ConsumeInt(8)],
|
||||||
|
Col10=fdp.ConsumeUnicode(20),
|
||||||
|
Col11=uuid4(),
|
||||||
|
Col12=WeekDays("{0:07b}".format(fdp.ConsumeIntInRange(0,31)))
|
||||||
|
)
|
||||||
|
ins.compile()
|
||||||
|
conn.execute(ins)
|
||||||
|
except (SQLAlchemyError, UnicodeEncodeError) as e:
|
||||||
|
pass
|
||||||
|
except ValueError as e:
|
||||||
|
if "the query contains a null character" not in str(e):
|
||||||
|
raise e
|
||||||
|
|
||||||
|
def main():
|
||||||
|
atheris.Setup(sys.argv, TestInput, enable_python_coverage=True)
|
||||||
|
atheris.Fuzz()
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
|
@ -0,0 +1,13 @@
|
||||||
|
fuzzing_engines:
|
||||||
|
- libfuzzer
|
||||||
|
homepage: https://github.com/kvesteri/sqlalchemy-utils
|
||||||
|
language: python
|
||||||
|
primary_contact: "contactme@kurtmckee.org"
|
||||||
|
main_repo: https://github.com/kvesteri/sqlalchemy-utils
|
||||||
|
sanitizers:
|
||||||
|
- address
|
||||||
|
- undefined
|
||||||
|
vendor_ccs:
|
||||||
|
- david@adalogics.com
|
||||||
|
- adam@adalogics.com
|
||||||
|
- arthur.chan@adalogics.com
|
Loading…
Reference in New Issue