Edit: I think the solution is to not have your upstream job failed in the first place, you can still handle failed downstream jobs with the help of i.e. env. variables or other means.
More information on the exact layout of your job would be helpful, however you can easily define how the result of your downstream job affects the upstream job.
As a Build step
Handy when you have one wrapper job that triggers multiple downstream jobs and to i.e. aggregates some results, you can easily specify how the result of a downstream job affects the wrapper job.
You just need to check the Block until the triggered projects finish their builds to have this option show up.
data:image/s3,"s3://crabby-images/fcfab/fcfab23d8267b40e12f93a301b42232cd7a5aa5a" alt="enter image description here"
The aviable options are explained as follows:
data:image/s3,"s3://crabby-images/fa640/fa6401789ae647ba861e6d460cc84020857d49a8" alt="enter image description here"
As a Post-build action
This is for chaining jobs to run after another, allowing you to specify the run condition
data:image/s3,"s3://crabby-images/f7b37/f7b37a86aa9e8ec1a4d95c94b46aa1758aa20100" alt="enter image description here"