Skip to content

Error 400 after successful file uploadΒ #1067

@rubyff

Description

@rubyff

Describe the bug

I'm testing an upload process, here's an anonymized snippet of the code:

    async def _upload_file(self, drive_id, filename, file_content, folder_name=None):
        properties = DriveItemUploadableProperties(
            additional_data={
                "@microsoft.graph.conflictBehavior" : "replace",
                },
            )
        request_body =  CreateUploadSessionPostRequestBody(item=properties)
        if folder_name is not None:
            filename = folder_name + '/' + filename
        session = await (
            self.client
            .drives.by_drive_id(drive_id)
            .items.by_drive_item_id(f"root:/{filename}:")
            .create_upload_session.post(body=request_body)
            )
        large_file_session = LargeFileUploadSession(
            upload_url=session.upload_url,
            expiration_date_time=session.expiration_date_time,
            additional_data=session.additional_data,
            is_cancelled=False,
            next_expected_ranges=session.next_expected_ranges
        )
        task = LargeFileUploadTask(upload_session=large_file_session, request_adapter=self.client.request_adapter, stream=file_content)

        upload_result = await task.upload()
        return upload_result

The upload proceeds as expected, but I get the following exception anyway:

APIError
Code: 400
message: The server returned an unexpected status code and no error class is registered for this code 400

Expected behavior

Either a more clear error code if there is a problem I'm not seeing, or no error after a successful upload.

How to reproduce

See code in first section.

SDK Version

1.17.0

Latest version known to work for scenario above?

No response

Known Workarounds

Ignoring the exception for error 400 works, but is not ideal.

Debug output

APIError
Code: 400
message: The server returned an unexpected status code and no error class is registered for this code 400

Configuration

Windows 11, x64. I haven't tested on any other systems at present.

Other information

This may not be related to the SDK at all, but if it is an error in the request that isn't clear from the documentation I've read on this. I will echo comments elsewhere that the documentation on using the SDK for uploads is extremely limited and I had to cobble a lot of this together from responses to other questions here.

Metadata

Metadata

Assignees

No one assigned

    Labels

    area:uploadsFocused on functional modules of the producttype:bugA broken experience

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions