Microsoft MVP성태의 닷넷 이야기
오류 유형: 770. twine 업로드 시 "HTTPError: 400 Bad Request ..." 오류 [링크 복사], [링크+제목 복사],
조회: 14930
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

twine 업로드 시 "HTTPError: 400 Bad Request ..." 오류

이상하군요, 동일한 setup.py로 패키징한 whl 파일을 윈도우에서는 정상적으로 업로드하는데, 리눅스 환경에서는 다음과 같은 식으로 오류가 발생합니다.

$ twine upload dist/...[생략]...-none-any.whl
...[생략]...
Uploading distributions to https://upload.pypi.org/legacy/
Uploading ...[생략]...-none-any.whl
100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 4.64M/4.64M [00:03<00:00, 1.50MB/s]
Error during upload. Retry with the --verbose option for more details.
HTTPError: 400 Bad Request from https://upload.pypi.org/legacy/
The description failed to render for 'text/x-rst'. See https://pypi.org/help/#description-content-type for more information.

이에 대한 확인을 twine 도구로 할 수 있습니다.

$ twine check dist/...[생략]...-none-any.whl
Checking dist/jennifer_python-5.3.0.15-py3-none-any.whl: FAILED
  `long_description` has syntax errors in markup and would not be rendered on PyPI.
    line 12: Warning: Title underline too short.

    패키지 사용법
    ----------

오류도 아닌, 경고에 불과한 것을 "FAILED" 처리했군요. ^^; (그러니까 윈도우 버전의 twine에서는 저런 검증 과정을 기본적으로 제공하지 않고 있었던 것입니다.) 암튼, 원인은 "패키지 사용법"의 글자보다 그 하단에 있는 "----------" 글자가 더 적기 때문입니다. 대충 아래와 같이 길이를 키워주시면 오류가 발생하지 않습니다.

    패키지 사용법
    ------------------




혹은 아래와 같은 오류가 발생한다면?

ERROR    `long_description` has syntax errors in markup and would not be rendered on PyPI.                                                                          line 114: Warning: malformed hyperlink target.

해당 line(위의 경우 114)에 가봤더니 다음과 같은 내용이 있는데,

.. _mysqlclient >= 2.0.3:: https://github.com/PyMySQL/mysqlclient-python

실수로 "2.0.3:: "과 같이 2개의 "::"을 넣었기 때문에 발생한 것입니다. 따라서 "2.0.3:"으로 바꾼 후 실행하면 잘 됩니다. ^^;





[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/7/2022]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2022-08-17 02시43분
restview 3.0.0
; https://pypi.org/project/restview/


$ pip install restview

$ restview test.rst
정성태

... 76  77  78  79  80  [81]  82  83  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
11911정성태5/23/201917479VS.NET IDE: 136. Visual Studio 2019 - 리눅스 C/C++ 프로젝트에 인텔리센스가 동작하지 않는 경우
11910정성태5/23/201927121Math: 50. C# - MathNet.Numerics의 Matrix(행렬) 연산 [1]파일 다운로드1
11909정성태5/22/201921152.NET Framework: 837. C# - PLplot 사용 예제 [1]파일 다운로드1
11908정성태5/22/201919913.NET Framework: 836. C# - Python range 함수 구현파일 다운로드1
11907정성태5/22/201916622오류 유형: 541. msbuild - MSB4024 The imported project file "...targets" could not be loaded
11906정성태5/21/201916869.NET Framework: 835. .NET Core/C# - 리눅스 syslog에 로그 남기는 방법
11905정성태5/21/201917382.NET Framework: 834. C# - 폴더 경로 문자열에서 "..", "." 표기를 고려한 최종 문자열을 얻는 방법 - 두 번째 이야기
11904정성태5/21/201925782.NET Framework: 833. C# - Open Hardware Monitor를 이용한 CPU 온도 정보 [1]파일 다운로드1
11903정성태5/21/201919607오류 유형: 540. .NET Core - System.PlatformNotSupportedException: The named version of this synchronization primitive is not supported on this platform.
11902정성태5/21/201917753오류 유형: 539. mstest 실행 시 "The directory name is invalid." 오류 발생
11901정성태5/21/201919658오류 유형: 538. msbuild 오류 - Could not find a part of the path '%LOCALAPPDATA%\Temp\2\.NETFramework,Version=v4.0.AssemblyAttributes.cs'
11900정성태5/18/201918629오류 유형: 537. "sfc /scannow" 실행 중 시스템이 부팅되는 현상
11899정성태5/17/201919451Linux: 9. Linux에서 윈도우의 OutputDebugString 대신 사용할 수 있는 syslog [1]
11898정성태5/16/201921261VC++: 130. C++ string의 c_str과 data 함수의 차이점 [3]
11897정성태5/16/201928229오류 유형: 536. Visual Studio - "Developer Pack"을 설치했는데도 "대상 프레임워크" 목록에 나오지 않는 경우 [2]
11896정성태5/15/201923163개발 환경 구성: 440. C#, C++ - double의 Infinity, NaN 표현 방식파일 다운로드1
11895정성태5/12/201921004.NET Framework: 832. ML.NET Model Builder - 회귀(Regression), 다중 분류(Multi-class classification) 예제파일 다운로드1
11894정성태5/10/201922729VS.NET IDE: 135. Visual Studio - ML.NET Model Builder 소개 [5]
11893정성태5/10/201919638오류 유형: 535. C# 6.0 이상의 문법을 컴파일 시 오류가 발생한다면?
11892정성태5/10/201919492웹: 38. HTTP Cookie의 expires 시간 형식(RFC7231)
11891정성태5/9/201922555.NET Framework: 831. (번역글) .NET Internals Cookbook Part 12 - Memory structure, attributes, handles
11890정성태5/8/201917675개발 환경 구성: 439. "Visual Studio Enterprise is required to execute the test." 메시지와 관련된 코드 기록
11889정성태5/8/201918342개발 환경 구성: 438. mstest, QTAgent의 로그 파일 설정 방법
11888정성태5/8/201935722.NET Framework: 830. C# - 비동기 호출을 취소하는 CancellationToken의 간단한 예제 코드 [1]파일 다운로드1
11887정성태5/8/201921339.NET Framework: 829. C# - yield 문을 사용할 수 있는 메서드의 조건
11886정성태5/7/201919164오류 유형: 534. mstest.exe 실행 시 "Visual Studio Enterprise is required to execute the test." 오류 [2]
... 76  77  78  79  80  [81]  82  83  84  85  86  87  88  89  90  ...